2013-05-19 04:28:07 +00:00
|
|
|
/******************************************************************************
|
|
|
|
*
|
|
|
|
* 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__
|
|
|
|
|
2013-08-12 04:36:23 +00:00
|
|
|
/* Definition */
|
|
|
|
/* CCK Rates, TxHT = 0 */
|
2013-08-15 03:03:17 +00:00
|
|
|
#define DESC92C_RATE1M 0x00
|
|
|
|
#define DESC92C_RATE2M 0x01
|
|
|
|
#define DESC92C_RATE5_5M 0x02
|
2013-05-19 04:28:07 +00:00
|
|
|
#define DESC92C_RATE11M 0x03
|
|
|
|
|
2013-08-12 04:36:23 +00:00
|
|
|
/* OFDM Rates, TxHT = 0 */
|
2013-08-15 03:03:17 +00:00
|
|
|
#define DESC92C_RATE6M 0x04
|
|
|
|
#define DESC92C_RATE9M 0x05
|
2013-05-19 04:28:07 +00:00
|
|
|
#define DESC92C_RATE12M 0x06
|
|
|
|
#define DESC92C_RATE18M 0x07
|
|
|
|
#define DESC92C_RATE24M 0x08
|
|
|
|
#define DESC92C_RATE36M 0x09
|
|
|
|
#define DESC92C_RATE48M 0x0a
|
|
|
|
#define DESC92C_RATE54M 0x0b
|
|
|
|
|
2013-08-12 04:36:23 +00:00
|
|
|
/* MCS Rates, TxHT = 1 */
|
2013-08-15 03:03:17 +00:00
|
|
|
#define DESC92C_RATEMCS0 0x0c
|
|
|
|
#define DESC92C_RATEMCS1 0x0d
|
|
|
|
#define DESC92C_RATEMCS2 0x0e
|
|
|
|
#define DESC92C_RATEMCS3 0x0f
|
|
|
|
#define DESC92C_RATEMCS4 0x10
|
|
|
|
#define DESC92C_RATEMCS5 0x11
|
|
|
|
#define DESC92C_RATEMCS6 0x12
|
|
|
|
#define DESC92C_RATEMCS7 0x13
|
|
|
|
#define DESC92C_RATEMCS8 0x14
|
|
|
|
#define DESC92C_RATEMCS9 0x15
|
|
|
|
#define DESC92C_RATEMCS10 0x16
|
|
|
|
#define DESC92C_RATEMCS11 0x17
|
|
|
|
#define DESC92C_RATEMCS12 0x18
|
|
|
|
#define DESC92C_RATEMCS13 0x19
|
|
|
|
#define DESC92C_RATEMCS14 0x1a
|
|
|
|
#define DESC92C_RATEMCS15 0x1b
|
2013-05-19 04:28:07 +00:00
|
|
|
#define DESC92C_RATEMCS15_SG 0x1c
|
2013-08-15 03:03:17 +00:00
|
|
|
#define DESC92C_RATEMCS32 0x20
|
2013-05-19 04:28:07 +00:00
|
|
|
|
2013-08-12 04:36:23 +00:00
|
|
|
/* structure and define */
|
2013-05-19 04:28:07 +00:00
|
|
|
|
2013-07-26 21:52:36 +00:00
|
|
|
struct phy_rx_agc_info {
|
2013-05-19 04:28:07 +00:00
|
|
|
#ifdef __LITTLE_ENDIAN
|
2013-08-15 03:03:17 +00:00
|
|
|
u8 gain:7, trsw:1;
|
2013-05-19 04:28:07 +00:00
|
|
|
#else
|
2013-08-15 03:03:17 +00:00
|
|
|
u8 trsw:1, gain:7;
|
2013-05-19 04:28:07 +00:00
|
|
|
#endif
|
2013-07-26 21:52:36 +00:00
|
|
|
};
|
2013-05-19 04:28:07 +00:00
|
|
|
|
2013-07-26 21:52:36 +00:00
|
|
|
struct phy_status_rpt {
|
2013-11-29 22:10:20 +00:00
|
|
|
struct phy_rx_agc_info path_agc[3];
|
2013-08-14 17:03:28 +00:00
|
|
|
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;
|
|
|
|
u8 path_cfotail[2];
|
|
|
|
u8 pcts_mask[2];
|
|
|
|
s8 stream_rxevm[2];
|
2013-11-29 22:10:20 +00:00
|
|
|
u8 path_rxsnr[3];
|
2013-08-14 17:03:28 +00:00
|
|
|
u8 noise_power_db_lsb;
|
|
|
|
u8 rsvd_2[3];
|
|
|
|
u8 stream_csi[2];
|
|
|
|
u8 stream_target_csi[2];
|
|
|
|
s8 sig_evm;
|
|
|
|
u8 rsvd_3;
|
2013-05-19 04:28:07 +00:00
|
|
|
|
|
|
|
#ifdef __LITTLE_ENDIAN
|
2013-08-14 17:03:28 +00:00
|
|
|
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;
|
2013-08-12 04:36:23 +00:00
|
|
|
#else /* _BIG_ENDIAN_ */
|
2013-08-14 17:03:28 +00:00
|
|
|
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; */
|
2013-05-19 04:28:07 +00:00
|
|
|
#endif
|
2013-07-26 21:52:36 +00:00
|
|
|
};
|
2013-05-19 04:28:07 +00:00
|
|
|
|
2013-08-15 03:03:17 +00:00
|
|
|
void odm_Init_RSSIForDM(struct odm_dm_struct *pDM_Odm);
|
2013-05-19 04:28:07 +00:00
|
|
|
|
2013-08-15 03:03:17 +00:00
|
|
|
void ODM_PhyStatusQuery(struct odm_dm_struct *pDM_Odm,
|
2013-07-26 16:20:42 +00:00
|
|
|
struct odm_phy_status_info *pPhyInfo,
|
2013-08-14 17:03:28 +00:00
|
|
|
u8 *pPhyStatus,
|
2013-08-15 03:03:17 +00:00
|
|
|
struct odm_per_pkt_info *pPktinfo);
|
2013-05-19 04:28:07 +00:00
|
|
|
|
2013-08-15 03:03:17 +00:00
|
|
|
void ODM_MacStatusQuery(struct odm_dm_struct *pDM_Odm,
|
2013-08-14 17:03:28 +00:00
|
|
|
u8 *pMacStatus,
|
2013-08-15 03:03:17 +00:00
|
|
|
u8 MacID,
|
|
|
|
bool bPacketMatchBSSID,
|
|
|
|
bool bPacketToSelf,
|
|
|
|
bool bPacketBeacon);
|
2013-07-15 04:50:52 +00:00
|
|
|
|
2013-08-15 03:03:17 +00:00
|
|
|
enum HAL_STATUS ODM_ConfigRFWithHeaderFile(struct odm_dm_struct *pDM_Odm,
|
|
|
|
enum ODM_RF_RADIO_PATH Content,
|
|
|
|
enum ODM_RF_RADIO_PATH eRFPath);
|
2013-05-19 04:28:07 +00:00
|
|
|
|
2013-08-15 03:03:17 +00:00
|
|
|
enum HAL_STATUS ODM_ConfigBBWithHeaderFile(struct odm_dm_struct *pDM_Odm,
|
2013-10-19 17:45:47 +00:00
|
|
|
enum odm_bb_config_type ConfigType);
|
2013-05-19 04:28:07 +00:00
|
|
|
|
2013-08-15 03:03:17 +00:00
|
|
|
enum HAL_STATUS ODM_ConfigMACWithHeaderFile(struct odm_dm_struct *pDM_Odm);
|
2013-05-19 04:28:07 +00:00
|
|
|
|
|
|
|
#endif
|