1a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger/****************************************************************************** 2a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger * 3a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger * Copyright(c) 2009-2014 Realtek Corporation. 4a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger * 5a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger * This program is free software; you can redistribute it and/or modify it 6a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger * under the terms of version 2 of the GNU General Public License as 7a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger * published by the Free Software Foundation. 8a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger * 9a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger * This program is distributed in the hope that it will be useful, but WITHOUT 10a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 11a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for 12a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger * more details. 13a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger * 14a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger * The full GNU General Public License is included in this distribution in the 15a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger * file called LICENSE. 16a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger * 17a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger * Contact Information: 18a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger * wlanfae <wlanfae@realtek.com> 19a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park, 20a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger * Hsinchu 300, Taiwan. 21a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger * Larry Finger <Larry.Finger@lwfinger.net> 22a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger * 23a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger *****************************************************************************/ 24a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger 25a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger#ifndef __RTL8723BE__FW__H__ 26a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger#define __RTL8723BE__FW__H__ 27a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger 28a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger#define FW_8192C_SIZE 0x8000 29a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger#define FW_8192C_START_ADDRESS 0x1000 30a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger#define FW_8192C_END_ADDRESS 0x5FFF 31a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger#define FW_8192C_PAGE_SIZE 4096 32a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger#define FW_8192C_POLLING_DELAY 5 33a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger 34a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger#define USE_OLD_WOWLAN_DEBUG_FW 0 35a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger 365c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger#define H2C_PWEMODE_LENGTH 5 37a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger 38a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger/* Fw PS state for RPWM. 39a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger*BIT[2:0] = HW state 40a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger*BIT[3] = Protocol PS state, 1: register active state , 0: register sleep state 41a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger*BIT[4] = sub-state 42a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger*/ 43a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger#define FW_PS_RF_ON BIT(2) 44a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger#define FW_PS_REGISTER_ACTIVE BIT(3) 45a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger 46a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger#define FW_PS_ACK BIT(6) 47a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger#define FW_PS_TOGGLE BIT(7) 48a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger 495c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger /* 8723BE RPWM value*/ 50a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger /* BIT[0] = 1: 32k, 0: 40M*/ 51a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger#define FW_PS_CLOCK_OFF BIT(0) /* 32k*/ 52a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger#define FW_PS_CLOCK_ON 0 /*40M*/ 53a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger 54a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger#define FW_PS_STATE_MASK (0x0F) 55a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger#define FW_PS_STATE_HW_MASK (0x07) 56a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger/*ISR_ENABLE, IMR_ENABLE, and PS mode should be inherited.*/ 57a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger#define FW_PS_STATE_INT_MASK (0x3F) 58a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger 595c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger#define FW_PS_STATE(x) (FW_PS_STATE_MASK & (x)) 60a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger 61a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger/* ((FW_PS_RF_ON) | (FW_PS_REGISTER_ACTIVE))*/ 625c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger#define FW_PS_STATE_ALL_ON (FW_PS_CLOCK_ON) 63a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger/* (FW_PS_RF_ON)*/ 645c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger#define FW_PS_STATE_RF_ON (FW_PS_CLOCK_ON) 65a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger/* 0x0*/ 665c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger#define FW_PS_STATE_RF_OFF (FW_PS_CLOCK_ON) 67a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger/* (FW_PS_STATE_RF_OFF)*/ 685c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger#define FW_PS_STATE_RF_OFF_LOW_PWR (FW_PS_CLOCK_OFF) 69a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger 70a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger 715c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger/* For 8723BE H2C PwrMode Cmd ID 5.*/ 72a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger#define FW_PWR_STATE_ACTIVE ((FW_PS_RF_ON) | (FW_PS_REGISTER_ACTIVE)) 73a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger#define FW_PWR_STATE_RF_OFF 0 74a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger 755c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger#define FW_PS_IS_ACK(x) ((x) & FW_PS_ACK) 76a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger 775c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger#define IS_IN_LOW_POWER_STATE(__fwpsstate) \ 785c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger (FW_PS_STATE(__fwpsstate) == FW_PS_CLOCK_OFF) 79a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger 80a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger#define FW_PWR_STATE_ACTIVE ((FW_PS_RF_ON) | (FW_PS_REGISTER_ACTIVE)) 81a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger#define FW_PWR_STATE_RF_OFF 0 82a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger 835c99f04fec93068147a3e95b439b345f203ac5b9Larry Fingerenum rtl8723b_h2c_cmd { 845c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger H2C_8723B_RSVDPAGE = 0, 855c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger H2C_8723B_MSRRPT = 1, 865c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger H2C_8723B_SCAN = 2, 875c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger H2C_8723B_KEEP_ALIVE_CTRL = 3, 885c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger H2C_8723B_DISCONNECT_DECISION = 4, 895c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger H2C_8723B_BCN_RSVDPAGE = 9, 905c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger H2C_8723B_PROBERSP_RSVDPAGE = 10, 915c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger 925c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger H2C_8723B_SETPWRMODE = 0x20, 935c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger H2C_8723B_PS_LPS_PARA = 0x23, 945c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger H2C_8723B_P2P_PS_OFFLOAD = 0x24, 955c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger 965c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger H2C_8723B_RA_MASK = 0x40, 975c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger H2C_RSSIBE_REPORT = 0x42, 985c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger /*Not defined CTW CMD for P2P yet*/ 995c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger H2C_8723B_P2P_PS_CTW_CMD, 1005c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger MAX_8723B_H2CCMD 1015c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger}; 1025c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger 1035c99f04fec93068147a3e95b439b345f203ac5b9Larry Fingerenum rtl8723b_c2h_evt { 1045c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger C2H_8723B_DBG = 0, 1055c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger C2H_8723B_LB = 1, 1065c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger C2H_8723B_TXBF = 2, 1075c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger C2H_8723B_TX_REPORT = 3, 1085c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger C2H_8723B_BT_INFO = 9, 1095c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger C2H_8723B_BT_MP = 11, 1105c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger MAX_8723B_C2HEVENT 1115c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger}; 1125c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger 1135c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger#define pagenum_128(_len) (u32)(((_len)>>7) + ((_len)&0x7F ? 1 : 0)) 114a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger 115a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger 116a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger#define SET_H2CCMD_PWRMODE_PARM_MODE(__ph2ccmd, __val) \ 117a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger SET_BITS_TO_LE_1BYTE(__ph2ccmd, 0, 8, __val) 118a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger#define SET_H2CCMD_PWRMODE_PARM_RLBM(__ph2ccmd, __val) \ 119a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger SET_BITS_TO_LE_1BYTE((__ph2ccmd)+1, 0, 4, __val) 120a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger#define SET_H2CCMD_PWRMODE_PARM_SMART_PS(__ph2ccmd, __val) \ 121a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger SET_BITS_TO_LE_1BYTE((__ph2ccmd)+1, 4, 4, __val) 122a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger#define SET_H2CCMD_PWRMODE_PARM_AWAKE_INTERVAL(__ph2ccmd, __val) \ 123a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger SET_BITS_TO_LE_1BYTE((__ph2ccmd)+2, 0, 8, __val) 124a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger#define SET_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD(__ph2ccmd, __val) \ 125a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger SET_BITS_TO_LE_1BYTE((__ph2ccmd)+3, 0, 8, __val) 126a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger#define SET_H2CCMD_PWRMODE_PARM_PWR_STATE(__ph2ccmd, __val) \ 127a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger SET_BITS_TO_LE_1BYTE((__ph2ccmd)+4, 0, 8, __val) 128a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger#define GET_88E_H2CCMD_PWRMODE_PARM_MODE(__ph2ccmd) \ 129a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger LE_BITS_TO_1BYTE(__ph2ccmd, 0, 8) 130a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger 1315c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger#define SET_H2CCMD_MSRRPT_PARM_OPMODE(__ph2ccmd, __val) \ 1325c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger SET_BITS_TO_LE_1BYTE(__ph2ccmd, 0, 1, __val) 1335c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger#define SET_H2CCMD_MSRRPT_PARM_MACID_IND(__ph2ccmd, __val) \ 1345c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger SET_BITS_TO_LE_1BYTE(__ph2ccmd, 1, 1, __val) 1355c99f04fec93068147a3e95b439b345f203ac5b9Larry Finger 136a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger#define SET_H2CCMD_RSVDPAGE_LOC_PROBE_RSP(__ph2ccmd, __val) \ 137a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger SET_BITS_TO_LE_1BYTE(__ph2ccmd, 0, 8, __val) 138a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger#define SET_H2CCMD_RSVDPAGE_LOC_PSPOLL(__ph2ccmd, __val) \ 139a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger SET_BITS_TO_LE_1BYTE((__ph2ccmd)+1, 0, 8, __val) 140a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger#define SET_H2CCMD_RSVDPAGE_LOC_NULL_DATA(__ph2ccmd, __val) \ 141a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger SET_BITS_TO_LE_1BYTE((__ph2ccmd)+2, 0, 8, __val) 142a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger 143a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger 144a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Fingervoid rtl8723be_fill_h2c_cmd(struct ieee80211_hw *hw, u8 element_id, 145a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger u32 cmd_len, u8 *p_cmdbuffer); 1465c99f04fec93068147a3e95b439b345f203ac5b9Larry Fingervoid rtl8723be_set_fw_pwrmode_cmd(struct ieee80211_hw *hw, u8 mode); 1475c99f04fec93068147a3e95b439b345f203ac5b9Larry Fingervoid rtl8723be_set_fw_media_status_rpt_cmd(struct ieee80211_hw *hw, u8 mstatus); 1485c99f04fec93068147a3e95b439b345f203ac5b9Larry Fingervoid rtl8723be_set_fw_rsvdpagepkt(struct ieee80211_hw *hw, bool b_dl_finished); 1495c99f04fec93068147a3e95b439b345f203ac5b9Larry Fingervoid rtl8723be_set_p2p_ps_offload_cmd(struct ieee80211_hw *hw, u8 p2p_ps_state); 1505c99f04fec93068147a3e95b439b345f203ac5b9Larry Fingervoid rtl8723be_c2h_packet_handler(struct ieee80211_hw *hw, u8 *buffer, u8 len); 151a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger 152a619d1abe20cc892ddd8f6f60345b24d43971fb4Larry Finger#endif 153