1 /****************************************************************************** 2 * 3 * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved. 4 * 5 * This program is free software; you can redistribute it and/or modify it 6 * under the terms of version 2 of the GNU General Public License as 7 * published by the Free Software Foundation. 8 * 9 * This program is distributed in the hope that it will be useful, but WITHOUT 10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for 12 * more details. 13 * 14 * You should have received a copy of the GNU General Public License along with 15 * this program; if not, write to the Free Software Foundation, Inc., 16 * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA 17 * 18 * 19 ******************************************************************************/ 20 #ifndef __COMMON_H2C_H__ 21 #define __COMMON_H2C_H__ 22 23 /* --------------------------------------------------------------------------------------------------------- 24 * ---------------------------------- H2C CMD DEFINITION ------------------------------------------------ 25 * --------------------------------------------------------------------------------------------------------- 26 * 88e, 8723b, 8812, 8821, 92e use the same FW code base */ 27 enum h2c_cmd { 28 /* Common Class: 000 */ 29 H2C_RSVD_PAGE = 0x00, 30 H2C_MEDIA_STATUS_RPT = 0x01, 31 H2C_SCAN_ENABLE = 0x02, 32 H2C_KEEP_ALIVE = 0x03, 33 H2C_DISCON_DECISION = 0x04, 34 H2C_PSD_OFFLOAD = 0x05, 35 H2C_AP_OFFLOAD = 0x08, 36 H2C_BCN_RSVDPAGE = 0x09, 37 H2C_PROBERSP_RSVDPAGE = 0x0A, 38 H2C_FCS_RSVDPAGE = 0x10, 39 H2C_FCS_INFO = 0x11, 40 H2C_AP_WOW_GPIO_CTRL = 0x13, 41 #ifdef CONFIG_MCC_MODE 42 H2C_MCC_UPDATE_PARAM = 0x15, 43 H2C_MCC_MACID_BITMAP = 0x16, 44 H2C_MCC_LOCATION = 0x10, 45 H2C_MCC_INFO = 0x18, 46 H2C_MCC_NOA_PARAM = 0x19, 47 H2C_MCC_IQK_PARAM = 0x1A, 48 #endif /* CONFIG_MCC_MODE */ 49 H2C_CHNL_SWITCH_OPER_OFFLOAD = 0x1C, 50 51 /* PoweSave Class: 001 */ 52 H2C_SET_PWR_MODE = 0x20, 53 H2C_PS_TUNING_PARA = 0x21, 54 H2C_PS_TUNING_PARA2 = 0x22, 55 H2C_P2P_LPS_PARAM = 0x23, 56 H2C_P2P_PS_OFFLOAD = 0x24, 57 H2C_PS_SCAN_ENABLE = 0x25, 58 H2C_SAP_PS_ = 0x26, 59 H2C_INACTIVE_PS_ = 0x27, /* Inactive_PS */ 60 H2C_FWLPS_IN_IPS_ = 0x28, 61 #ifdef CONFIG_LPS_POFF 62 H2C_LPS_POFF_CTRL = 0x29, 63 H2C_LPS_POFF_PARAM = 0x2A, 64 #endif 65 #ifdef CONFIG_LPS_PG 66 H2C_LPS_PG_INFO = 0x2B, 67 #endif 68 /* Dynamic Mechanism Class: 010 */ 69 H2C_MACID_CFG = 0x40, 70 H2C_TXBF = 0x41, 71 H2C_RSSI_SETTING = 0x42, 72 H2C_AP_REQ_TXRPT = 0x43, 73 H2C_INIT_RATE_COLLECT = 0x44, 74 H2C_IQ_CALIBRATION = 0x45, 75 76 H2C_RA_MASK_3SS = 0x46,/* for 8814A */ 77 H2C_RA_PARA_ADJUST = 0x47,/* CONFIG_RA_DBG_CMD */ 78 H2C_DYNAMIC_TX_PATH = 0x48,/* for 8814A */ 79 80 H2C_FW_TRACE_EN = 0x49, 81 82 /* BT Class: 011 */ 83 H2C_B_TYPE_TDMA = 0x60, 84 H2C_BT_INFO = 0x61, 85 H2C_FORCE_BT_TXPWR = 0x62, 86 H2C_BT_IGNORE_WLANACT = 0x63, 87 H2C_DAC_SWING_VALUE = 0x64, 88 H2C_ANT_SEL_RSV = 0x65, 89 H2C_WL_OPMODE = 0x66, 90 H2C_BT_MP_OPER = 0x67, 91 H2C_BT_CONTROL = 0x68, 92 H2C_BT_WIFI_CTRL = 0x69, 93 H2C_BT_FW_PATCH = 0x6A, 94 H2C_BTC_WL_PORT_ID = 0x71, 95 96 /* WOWLAN Class: 100 */ 97 H2C_WOWLAN = 0x80, 98 H2C_REMOTE_WAKE_CTRL = 0x81, 99 H2C_AOAC_GLOBAL_INFO = 0x82, 100 H2C_AOAC_RSVD_PAGE = 0x83, 101 H2C_AOAC_RSVD_PAGE2 = 0x84, 102 H2C_D0_SCAN_OFFLOAD_CTRL = 0x85, 103 H2C_D0_SCAN_OFFLOAD_INFO = 0x86, 104 H2C_CHNL_SWITCH_OFFLOAD = 0x87, 105 H2C_AOAC_RSVDPAGE3 = 0x88, 106 H2C_P2P_OFFLOAD_RSVD_PAGE = 0x8A, 107 H2C_P2P_OFFLOAD = 0x8B, 108 109 H2C_RESET_TSF = 0xC0, 110 H2C_BCNHWSEQ = 0xC5, 111 H2C_MAXID, 112 }; 113 114 #define H2C_INACTIVE_PS_LEN 3 115 #define H2C_RSVDPAGE_LOC_LEN 5 116 #define H2C_MEDIA_STATUS_RPT_LEN 3 117 #define H2C_KEEP_ALIVE_CTRL_LEN 2 118 #define H2C_DISCON_DECISION_LEN 3 119 #define H2C_AP_OFFLOAD_LEN 3 120 #define H2C_AP_WOW_GPIO_CTRL_LEN 4 121 #define H2C_AP_PS_LEN 2 122 #define H2C_PWRMODE_LEN 7 123 #define H2C_PSTUNEPARAM_LEN 4 124 #define H2C_MACID_CFG_LEN 7 125 #define H2C_BTMP_OPER_LEN 5 126 #define H2C_WOWLAN_LEN 5 127 #define H2C_REMOTE_WAKE_CTRL_LEN 3 128 #define H2C_AOAC_GLOBAL_INFO_LEN 2 129 #define H2C_AOAC_RSVDPAGE_LOC_LEN 7 130 #define H2C_SCAN_OFFLOAD_CTRL_LEN 4 131 #define H2C_BT_FW_PATCH_LEN 6 132 #define H2C_RSSI_SETTING_LEN 4 133 #define H2C_AP_REQ_TXRPT_LEN 3 134 #define H2C_FORCE_BT_TXPWR_LEN 3 135 #define H2C_BCN_RSVDPAGE_LEN 5 136 #define H2C_PROBERSP_RSVDPAGE_LEN 5 137 #define H2C_P2PRSVDPAGE_LOC_LEN 5 138 #define H2C_P2P_OFFLOAD_LEN 3 139 #ifdef CONFIG_MCC_MODE 140 #define H2C_MCC_INFO_LEN 7 141 #define H2C_MCC_LOCATION_LEN 3 142 #define H2C_MCC_MACID_BITMAP_LEN 6 143 #define H2C_MCC_UPDATE_INFO_LEN 4 144 #define H2C_MCC_NOA_PARAM_LEN 4 145 #define H2C_MCC_IQK_PARAM_LEN 7 146 #endif /* CONFIG_MCC_MODE */ 147 #ifdef CONFIG_LPS_PG 148 #define H2C_LPS_PG_INFO_LEN 2 149 #define H2C_LPSPG_LEN 16 150 #endif 151 #ifdef CONFIG_LPS_POFF 152 #define H2C_LPS_POFF_CTRL_LEN 1 153 #define H2C_LPS_POFF_PARAM_LEN 5 154 #endif 155 #define H2C_BTC_WL_PORT_ID_LEN 1 156 157 #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) 158 #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]) 159 #define cpIpAddr(des, src) ((des)[0] = (src)[0], (des)[1] = (src)[1], (des)[2] = (src)[2], (des)[3] = (src)[3]) 160 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN) 161 /* 162 * ARP packet 163 * 164 * LLC Header */ 165 #define GET_ARP_PKT_LLC_TYPE(__pHeader) ReadLE2Byte(((u8 *)(__pHeader)) + 6) 166 167 /* ARP element */ 168 #define GET_ARP_PKT_OPERATION(__pHeader) ReadLE2Byte(((u8 *)(__pHeader)) + 6) 169 #define GET_ARP_PKT_SENDER_MAC_ADDR(__pHeader, _val) cpMacAddr((u8 *)(_val), ((u8 *)(__pHeader))+8) 170 #define GET_ARP_PKT_SENDER_IP_ADDR(__pHeader, _val) cpIpAddr((u8 *)(_val), ((u8 *)(__pHeader))+14) 171 #define GET_ARP_PKT_TARGET_MAC_ADDR(__pHeader, _val) cpMacAddr((u8 *)(_val), ((u8 *)(__pHeader))+18) 172 #define GET_ARP_PKT_TARGET_IP_ADDR(__pHeader, _val) cpIpAddr((u8 *)(_val), ((u8 *)(__pHeader))+24) 173 174 #define SET_ARP_PKT_HW(__pHeader, __Value) WriteLE2Byte(((u8 *)(__pHeader)) + 0, __Value) 175 #define SET_ARP_PKT_PROTOCOL(__pHeader, __Value) WriteLE2Byte(((u8 *)(__pHeader)) + 2, __Value) 176 #define SET_ARP_PKT_HW_ADDR_LEN(__pHeader, __Value) WriteLE1Byte(((u8 *)(__pHeader)) + 4, __Value) 177 #define SET_ARP_PKT_PROTOCOL_ADDR_LEN(__pHeader, __Value) WriteLE1Byte(((u8 *)(__pHeader)) + 5, __Value) 178 #define SET_ARP_PKT_OPERATION(__pHeader, __Value) WriteLE2Byte(((u8 *)(__pHeader)) + 6, __Value) 179 #define SET_ARP_PKT_SENDER_MAC_ADDR(__pHeader, _val) cpMacAddr(((u8 *)(__pHeader))+8, (u8 *)(_val)) 180 #define SET_ARP_PKT_SENDER_IP_ADDR(__pHeader, _val) cpIpAddr(((u8 *)(__pHeader))+14, (u8 *)(_val)) 181 #define SET_ARP_PKT_TARGET_MAC_ADDR(__pHeader, _val) cpMacAddr(((u8 *)(__pHeader))+18, (u8 *)(_val)) 182 #define SET_ARP_PKT_TARGET_IP_ADDR(__pHeader, _val) cpIpAddr(((u8 *)(__pHeader))+24, (u8 *)(_val)) 183 184 #define FW_WOWLAN_FUN_EN BIT(0) 185 #define FW_WOWLAN_PATTERN_MATCH BIT(1) 186 #define FW_WOWLAN_MAGIC_PKT BIT(2) 187 #define FW_WOWLAN_UNICAST BIT(3) 188 #define FW_WOWLAN_ALL_PKT_DROP BIT(4) 189 #define FW_WOWLAN_GPIO_ACTIVE BIT(5) 190 #define FW_WOWLAN_REKEY_WAKEUP BIT(6) 191 #define FW_WOWLAN_DEAUTH_WAKEUP BIT(7) 192 193 #define FW_WOWLAN_GPIO_WAKEUP_EN BIT(0) 194 #define FW_FW_PARSE_MAGIC_PKT BIT(1) 195 196 #define FW_REMOTE_WAKE_CTRL_EN BIT(0) 197 #define FW_REALWOWLAN_EN BIT(5) 198 199 #define FW_WOWLAN_KEEP_ALIVE_EN BIT(0) 200 #define FW_ADOPT_USER BIT(1) 201 #define FW_WOWLAN_KEEP_ALIVE_PKT_TYPE BIT(2) 202 203 #define FW_REMOTE_WAKE_CTRL_EN BIT(0) 204 #define FW_ARP_EN BIT(1) 205 #define FW_REALWOWLAN_EN BIT(5) 206 #define FW_WOW_FW_UNICAST_EN BIT(7) 207 208 #endif /* CONFIG_WOWLAN */ 209 210 /* _RSVDPAGE_LOC_CMD_0x00 */ 211 #define SET_H2CCMD_RSVDPAGE_LOC_PROBE_RSP(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value) 212 #define SET_H2CCMD_RSVDPAGE_LOC_PSPOLL(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value) 213 #define SET_H2CCMD_RSVDPAGE_LOC_NULL_DATA(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value) 214 #define SET_H2CCMD_RSVDPAGE_LOC_QOS_NULL_DATA(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value) 215 #define SET_H2CCMD_RSVDPAGE_LOC_BT_QOS_NULL_DATA(__pH2CCmd, __Value)SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value) 216 217 /* _MEDIA_STATUS_RPT_PARM_CMD_0x01 */ 218 #define SET_H2CCMD_MSRRPT_PARM_OPMODE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 0, 1, (__Value)) 219 #define SET_H2CCMD_MSRRPT_PARM_MACID_IND(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 1, 1, (__Value)) 220 #define SET_H2CCMD_MSRRPT_PARM_MIRACAST(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 2, 1, (__Value)) 221 #define SET_H2CCMD_MSRRPT_PARM_MIRACAST_SINK(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 3, 1, (__Value)) 222 #define SET_H2CCMD_MSRRPT_PARM_ROLE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 4, 4, (__Value)) 223 #define SET_H2CCMD_MSRRPT_PARM_MACID(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)) + 1, 0, 8, (__Value)) 224 #define SET_H2CCMD_MSRRPT_PARM_MACID_END(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)) + 2, 0, 8, (__Value)) 225 226 #define GET_H2CCMD_MSRRPT_PARM_OPMODE(__pH2CCmd) LE_BITS_TO_1BYTE(((u8 *)(__pH2CCmd)), 0, 1) 227 #define GET_H2CCMD_MSRRPT_PARM_MIRACAST(__pH2CCmd) LE_BITS_TO_1BYTE(((u8 *)(__pH2CCmd)), 2, 1) 228 #define GET_H2CCMD_MSRRPT_PARM_MIRACAST_SINK(__pH2CCmd) LE_BITS_TO_1BYTE(((u8 *)(__pH2CCmd)), 3, 1) 229 #define GET_H2CCMD_MSRRPT_PARM_ROLE(__pH2CCmd) LE_BITS_TO_1BYTE(((u8 *)(__pH2CCmd)), 4, 4) 230 231 #define H2C_MSR_ROLE_RSVD 0 232 #define H2C_MSR_ROLE_STA 1 233 #define H2C_MSR_ROLE_AP 2 234 #define H2C_MSR_ROLE_GC 3 235 #define H2C_MSR_ROLE_GO 4 236 #define H2C_MSR_ROLE_TDLS 5 237 #define H2C_MSR_ROLE_ADHOC 6 238 #define H2C_MSR_ROLE_MAX 7 239 240 extern const char *const _h2c_msr_role_str[]; 241 #define h2c_msr_role_str(role) (((role) >= H2C_MSR_ROLE_MAX) ? _h2c_msr_role_str[H2C_MSR_ROLE_MAX] : _h2c_msr_role_str[(role)]) 242 243 #define H2C_MSR_FMT "%s %s%s" 244 #define H2C_MSR_ARG(h2c_msr) \ 245 GET_H2CCMD_MSRRPT_PARM_OPMODE((h2c_msr)) ? " C" : "", \ 246 h2c_msr_role_str(GET_H2CCMD_MSRRPT_PARM_ROLE((h2c_msr))), \ 247 GET_H2CCMD_MSRRPT_PARM_MIRACAST((h2c_msr)) ? (GET_H2CCMD_MSRRPT_PARM_MIRACAST_SINK((h2c_msr)) ? " MSINK" : " MSRC") : "" 248 249 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); 250 s32 rtw_hal_set_FwMediaStatusRpt_single_cmd(_adapter *adapter, bool opmode, bool miracast, bool miracast_sink, u8 role, u8 macid); 251 s32 rtw_hal_set_FwMediaStatusRpt_range_cmd(_adapter *adapter, bool opmode, bool miracast, bool miracast_sink, u8 role, u8 macid, u8 macid_end); 252 253 /* _KEEP_ALIVE_CMD_0x03 */ 254 #define SET_H2CCMD_KEEPALIVE_PARM_ENABLE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value) 255 #define SET_H2CCMD_KEEPALIVE_PARM_ADOPT(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value) 256 #define SET_H2CCMD_KEEPALIVE_PARM_PKT_TYPE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value) 257 #define SET_H2CCMD_KEEPALIVE_PARM_CHECK_PERIOD(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value) 258 259 /* _DISCONNECT_DECISION_CMD_0x04 */ 260 #define SET_H2CCMD_DISCONDECISION_PARM_ENABLE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value) 261 #define SET_H2CCMD_DISCONDECISION_PARM_ADOPT(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value) 262 #define SET_H2CCMD_DISCONDECISION_PARM_CHECK_PERIOD(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value) 263 #define SET_H2CCMD_DISCONDECISION_PARM_TRY_PKT_NUM(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 8, __Value) 264 265 /* _AP_Offload 0x08 */ 266 #define SET_H2CCMD_AP_WOWLAN_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value) 267 /* _BCN_RsvdPage 0x09 */ 268 #define SET_H2CCMD_AP_WOWLAN_RSVDPAGE_LOC_BCN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value) 269 /* _Probersp_RsvdPage 0x0a */ 270 #define SET_H2CCMD_AP_WOWLAN_RSVDPAGE_LOC_ProbeRsp(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value) 271 /* _Probersp_RsvdPage 0x13 */ 272 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_INDEX(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value) 273 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_C2H_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 1, __Value) 274 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_PLUS(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 5, 1, __Value) 275 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_HIGH_ACTIVE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 6, 1, __Value) 276 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 7, 1, __Value) 277 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_DURATION(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value) 278 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_C2H_DURATION(__pH2CCmd, __Value)SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value) 279 /* _AP_PS 0x26 */ 280 #define SET_H2CCMD_AP_WOW_PS_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value) 281 #define SET_H2CCMD_AP_WOW_PS_32K_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value) 282 #define SET_H2CCMD_AP_WOW_PS_RF(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value) 283 #define SET_H2CCMD_AP_WOW_PS_DURATION(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value) 284 285 #ifdef CONFIG_LPS_POFF 286 /*PARTIAL OFF Control 0x29*/ 287 #define SET_H2CCMD_LPS_POFF_CTRL_EN(__pH2CCmd, __Value) \ 288 SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value) 289 /*PARTIAL OFF PARAM 0x2A*/ 290 #define SET_H2CCMD_LPS_POFF_PARAM_RDVLD(__pH2CCmd, __Value) \ 291 SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value) 292 #define SET_H2CCMD_LPS_POFF_PARAM_WRVLD(__pH2CCmd, __Value) \ 293 SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value) 294 #define SET_H2CCMD_LPS_POFF_PARAM_STARTADDL(__pH2CCmd, __Value) \ 295 SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value) 296 #define SET_H2CCMD_LPS_POFF_PARAM_STARTADDH(__pH2CCmd, __Value) \ 297 SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 8, __Value) 298 #define SET_H2CCMD_LPS_POFF_PARAM_ENDADDL(__pH2CCmd, __Value) \ 299 SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value) 300 #define SET_H2CCMD_LPS_POFF_PARAM_ENDADDH(__pH2CCmd, __Value) \ 301 SET_BITS_TO_LE_1BYTE(__pH2CCmd+4, 0, 8, __Value) 302 #endif 303 304 #ifdef CONFIG_MCC_MODE 305 /* MCC LOC CMD 0x10 */ 306 #define SET_H2CCMD_MCC_RSVDPAGE_LOC(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value) 307 308 /* MCC MAC ID CMD 0x16 */ 309 #define SET_H2CCMD_MCC_MACID_BITMAP_L(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value) 310 #define SET_H2CCMD_MCC_MACID_BITMAP_H(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value) 311 312 /* MCC INFO CMD 0x18 */ 313 #define SET_H2CCMD_MCC_INFO_ORDER(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value) 314 #define SET_H2CCMD_MCC_INFO_TOTALNUM(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 4, __Value) 315 #define SET_H2CCMD_MCC_INFO_CHIDX(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value) 316 #define SET_H2CCMD_MCC_INFO_BW(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 2, __Value) 317 #define SET_H2CCMD_MCC_INFO_BW40SC(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 2, 3, __Value) 318 #define SET_H2CCMD_MCC_INFO_BW80SC(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 5, 3, __Value) 319 #define SET_H2CCMD_MCC_INFO_DURATION(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value) 320 #define SET_H2CCMD_MCC_INFO_ROLE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 3, __Value) 321 #define SET_H2CCMD_MCC_INFO_INCURCH(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 3, 1, __Value) 322 #define SET_H2CCMD_MCC_INFO_RSVD0(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 4, 4, __Value) 323 #define SET_H2CCMD_MCC_INFO_RSVD1(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value) 324 #define SET_H2CCMD_MCC_INFO_RFETYPE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 0, 4, __Value) 325 #define SET_H2CCMD_MCC_INFO_DISTXNULL(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 4, 1, __Value) 326 #define SET_H2CCMD_MCC_INFO_C2HRPT(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 5, 2, __Value) 327 #define SET_H2CCMD_MCC_INFO_CHSCAN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 7, 1, __Value) 328 329 /* MCC NoA CMD 0x19 */ 330 #define SET_H2CCMD_MCC_NOA_FW_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value) 331 #define SET_H2CCMD_MCC_NOA_TSF_SYNC_OFFSET(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 7, __Value) 332 #define SET_H2CCMD_MCC_NOA_START_TIME(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value) 333 #define SET_H2CCMD_MCC_NOA_INTERVAL(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value) 334 #define SET_H2CCMD_MCC_EARLY_TIME(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value) 335 336 /* MCC IQK CMD 0x1A */ 337 #define SET_H2CCMD_MCC_IQK_READY(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value) 338 #define SET_H2CCMD_MCC_IQK_ORDER(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 2, __Value) 339 #define SET_H2CCMD_MCC_IQK_RX_L(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value) 340 #define SET_H2CCMD_MCC_IQK_RX_M1(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 2, __Value) 341 #define SET_H2CCMD_MCC_IQK_RX_M2(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 2, 6, __Value) 342 #define SET_H2CCMD_MCC_IQK_RX_H(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 4, __Value) 343 #define SET_H2CCMD_MCC_IQK_TX_L(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value) 344 #define SET_H2CCMD_MCC_IQK_TX_M1(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 3, __Value) 345 #define SET_H2CCMD_MCC_IQK_TX_M2(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 3, 5, __Value) 346 #define SET_H2CCMD_MCC_IQK_TX_H(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 0, 6, __Value) 347 #endif /* CONFIG_MCC_MODE */ 348 349 /* CHNL SWITCH OPER OFFLOAD 0x1C */ 350 #define SET_H2CCMD_CH_SW_OPER_OFFLOAD_CH_NUM(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value) 351 #define SET_H2CCMD_CH_SW_OPER_OFFLOAD_BW_MODE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 1, 0, 2, __Value) 352 #define SET_H2CCMD_CH_SW_OPER_OFFLOAD_BW_40M_SC(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 1, 2, 3, __Value) 353 #define SET_H2CCMD_CH_SW_OPER_OFFLOAD_BW_80M_SC(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 1, 5, 3, __Value) 354 #define SET_H2CCMD_CH_SW_OPER_OFFLOAD_RFE_TYPE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 2, 0, 4, __Value) 355 356 #ifdef CONFIG_BT_COEXIST 357 #define SET_H2CCMD_BTC_WL_PORT_ID(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value) 358 #endif 359 360 /* _WoWLAN PARAM_CMD_0x80 */ 361 #define SET_H2CCMD_WOWLAN_FUNC_ENABLE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value) 362 #define SET_H2CCMD_WOWLAN_PATTERN_MATCH_ENABLE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value) 363 #define SET_H2CCMD_WOWLAN_MAGIC_PKT_ENABLE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value) 364 #define SET_H2CCMD_WOWLAN_UNICAST_PKT_ENABLE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 1, __Value) 365 #define SET_H2CCMD_WOWLAN_ALL_PKT_DROP(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 1, __Value) 366 #define SET_H2CCMD_WOWLAN_GPIO_ACTIVE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 5, 1, __Value) 367 #define SET_H2CCMD_WOWLAN_REKEY_WAKE_UP(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 6, 1, __Value) 368 #define SET_H2CCMD_WOWLAN_DISCONNECT_WAKE_UP(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 7, 1, __Value) 369 #define SET_H2CCMD_WOWLAN_GPIONUM(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 7, __Value) 370 #define SET_H2CCMD_WOWLAN_DATAPIN_WAKE_UP(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 7, 1, __Value) 371 #define SET_H2CCMD_WOWLAN_GPIO_DURATION(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value) 372 #define SET_H2CCMD_WOWLAN_GPIO_PULSE_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 1, __Value) 373 #define SET_H2CCMD_WOWLAN_GPIO_PULSE_COUNT(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 1, 7, __Value) 374 #define SET_H2CCMD_WOWLAN_LOWPR_RX(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 1, __Value) 375 #define SET_H2CCMD_WOWLAN_CHANGE_UNIT(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 2, 1, __Value) 376 /* _REMOTE_WAKEUP_CMD_0x81 */ 377 #define SET_H2CCMD_REMOTE_WAKECTRL_ENABLE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value) 378 #define SET_H2CCMD_REMOTE_WAKE_CTRL_ARP_OFFLOAD_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value) 379 #define SET_H2CCMD_REMOTE_WAKE_CTRL_NDP_OFFLOAD_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value) 380 #define SET_H2CCMD_REMOTE_WAKE_CTRL_GTK_OFFLOAD_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 1, __Value) 381 #define SET_H2CCMD_REMOTE_WAKE_CTRL_NLO_OFFLOAD_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 1, __Value) 382 #define SET_H2CCMD_REMOTE_WAKE_CTRL_FW_UNICAST_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 7, 1, __Value) 383 #define SET_H2CCMD_REMOTE_WAKE_CTRL_P2P_OFFLAD_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 1, __Value) 384 #define SET_H2CCMD_REMOTE_WAKE_CTRL_NBNS_FILTER_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 2, 1, __Value) 385 #define SET_H2CCMD_REMOTE_WAKE_CTRL_ARP_ACTION(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 1, __Value) 386 #define SET_H2CCMD_REMOTE_WAKE_CTRL_FW_PARSING_UNTIL_WAKEUP(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 4, 1, __Value) 387 388 /* AOAC_GLOBAL_INFO_0x82 */ 389 #define SET_H2CCMD_AOAC_GLOBAL_INFO_PAIRWISE_ENC_ALG(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value) 390 #define SET_H2CCMD_AOAC_GLOBAL_INFO_GROUP_ENC_ALG(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value) 391 392 /* AOAC_RSVDPAGE_LOC_0x83 */ 393 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_REMOTE_WAKE_CTRL_INFO(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd), 0, 8, __Value) 394 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_ARP_RSP(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value) 395 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_NEIGHBOR_ADV(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value) 396 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_GTK_RSP(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value) 397 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_GTK_INFO(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value) 398 #ifdef CONFIG_GTK_OL 399 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_GTK_EXT_MEM(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value) 400 #endif /* CONFIG_GTK_OL */ 401 #ifdef CONFIG_PNO_SUPPORT 402 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_NLO_INFO(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd), 0, 8, __Value) 403 #endif 404 405 #ifdef CONFIG_PNO_SUPPORT 406 /* D0_Scan_Offload_Info_0x86 */ 407 #define SET_H2CCMD_AOAC_NLO_FUN_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd), 3, 1, __Value) 408 #define SET_H2CCMD_AOAC_NLO_IPS_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd), 4, 1, __Value) 409 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_PROBE_PACKET(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value) 410 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_SCAN_INFO(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value) 411 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_SSID_INFO(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value) 412 #endif /* CONFIG_PNO_SUPPORT */ 413 414 #ifdef CONFIG_P2P_WOWLAN 415 /* P2P_RsvdPage_0x8a */ 416 #define SET_H2CCMD_RSVDPAGE_LOC_P2P_BCN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value) 417 #define SET_H2CCMD_RSVDPAGE_LOC_P2P_PROBE_RSP(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value) 418 #define SET_H2CCMD_RSVDPAGE_LOC_P2P_NEGO_RSP(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value) 419 #define SET_H2CCMD_RSVDPAGE_LOC_P2P_INVITE_RSP(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value) 420 #define SET_H2CCMD_RSVDPAGE_LOC_P2P_PD_RSP(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value) 421 #endif /* CONFIG_P2P_WOWLAN */ 422 423 #ifdef CONFIG_LPS_PG 424 #define SET_H2CCMD_LPSPG_SEC_CAM_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)/*SecurityCAM_En*/ 425 #define SET_H2CCMD_LPSPG_MBID_CAM_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)/*BSSIDCAM_En*/ 426 #define SET_H2CCMD_LPSPG_PMC_CAM_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)/*PatternMatchCAM_En*/ 427 #define SET_H2CCMD_LPSPG_MACID_SEARCH_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 1, __Value)/*MACIDSearch_En*/ 428 #define SET_H2CCMD_LPSPG_TXSC_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 1, __Value)/*TXSC_En*/ 429 #define SET_H2CCMD_LPSPG_MU_RATE_TB_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 5, 1, __Value)/*MURateTable_En*/ 430 #define SET_H2CCMD_LPSPG_LOC(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)/*Loc_LPS_PG*/ 431 #endif 432 433 /* --------------------------------------------------------------------------------------------------------- 434 * ------------------------------------------- Structure -------------------------------------------------- 435 * --------------------------------------------------------------------------------------------------------- */ 436 typedef struct _RSVDPAGE_LOC { 437 u8 LocProbeRsp; 438 u8 LocPsPoll; 439 u8 LocNullData; 440 u8 LocQosNull; 441 u8 LocBTQosNull; 442 #ifdef CONFIG_WOWLAN 443 u8 LocRemoteCtrlInfo; 444 u8 LocArpRsp; 445 u8 LocNbrAdv; 446 u8 LocGTKRsp; 447 u8 LocGTKInfo; 448 u8 LocProbeReq; 449 u8 LocNetList; 450 #ifdef CONFIG_GTK_OL 451 u8 LocGTKEXTMEM; 452 #endif /* CONFIG_GTK_OL */ 453 #ifdef CONFIG_PNO_SUPPORT 454 u8 LocPNOInfo; 455 u8 LocScanInfo; 456 u8 LocSSIDInfo; 457 u8 LocProbePacket; 458 #endif /* CONFIG_PNO_SUPPORT */ 459 #endif /* CONFIG_WOWLAN */ 460 u8 LocApOffloadBCN; 461 #ifdef CONFIG_P2P_WOWLAN 462 u8 LocP2PBeacon; 463 u8 LocP2PProbeRsp; 464 u8 LocNegoRsp; 465 u8 LocInviteRsp; 466 u8 LocPDRsp; 467 #endif /* CONFIG_P2P_WOWLAN */ 468 } RSVDPAGE_LOC, *PRSVDPAGE_LOC; 469 470 #endif 471 void dump_TX_FIFO(PADAPTER padapter, u8 page_num, u16 page_size); 472 u8 rtw_hal_set_fw_media_status_cmd(_adapter *adapter, u8 mstatus, u8 macid); 473 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN) 474 /* WOW command function */ 475 void rtw_hal_set_fw_wow_related_cmd(_adapter *padapter, u8 enable); 476 #ifdef CONFIG_P2P_WOWLAN 477 /* H2C 0x8A */ 478 u8 rtw_hal_set_FwP2PRsvdPage_cmd(_adapter *adapter, PRSVDPAGE_LOC rsvdpageloc); 479 /* H2C 0x8B */ 480 u8 rtw_hal_set_p2p_wowlan_offload_cmd(_adapter *adapter); 481 #endif /* CONFIG_P2P_WOWLAN */ 482 #endif 483