1
0
mirror of https://github.com/aircrack-ng/rtl8812au.git synced 2024-09-20 05:00:36 +00:00
rtl8812au/hal/phydm/phydm_primary_cca.h

88 lines
2.9 KiB
C
Raw Normal View History

2018-06-22 16:48:32 +00:00
/******************************************************************************
*
2018-08-24 20:52:34 +00:00
* Copyright(c) 2007 - 2017 Realtek Corporation.
2018-06-22 16:48:32 +00:00
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
2018-08-24 20:52:34 +00:00
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
2018-06-22 16:48:32 +00:00
* more details.
*
2018-08-24 20:52:34 +00:00
* The full GNU General Public License is included in this distribution in the
* file called LICENSE.
*
* Contact Information:
* wlanfae <wlanfae@realtek.com>
* Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
* Hsinchu 300, Taiwan.
*
* Larry Finger <Larry.Finger@lwfinger.net>
*
2018-06-22 16:48:32 +00:00
*****************************************************************************/
2019-05-24 19:43:57 +00:00
#ifndef __PHYDM_PRIMARYCCA_H__
#define __PHYDM_PRIMARYCCA_H__
2018-06-22 16:48:32 +00:00
2019-05-24 19:43:57 +00:00
#ifdef PHYDM_PRIMARY_CCA
#define PRIMARYCCA_VERSION "2.0"
2018-06-22 16:48:32 +00:00
2019-05-24 19:43:57 +00:00
/*@============================================================*/
/*@Definition */
/*@============================================================*/
2018-06-22 16:48:32 +00:00
#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
2019-05-24 19:43:57 +00:00
#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*/
2018-06-22 16:48:32 +00:00
#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
2019-05-24 19:43:57 +00:00
#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*/
2018-06-22 16:48:32 +00:00
#else /*if (DM_ODM_SUPPORT_TYPE == ODM_AP)*/
2019-05-24 19:43:57 +00:00
#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*/
2018-06-22 16:48:32 +00:00
#endif
2019-05-24 19:43:57 +00:00
#define OFDMCCA_TH 500
2018-06-22 16:48:32 +00:00
#define bw_ind_bias 500
#define PRI_CCA_MONITOR_TIME 30
2019-05-24 19:43:57 +00:00
/*@============================================================*/
2018-06-22 16:48:32 +00:00
/*structure and define*/
2019-05-24 19:43:57 +00:00
/*@============================================================*/
enum primary_cca_ch_position { /*N-series REG0xc6c[8:7]*/
MF_USC_LSC = 0,
MF_LSC = 1,
MF_USC = 2
2018-06-22 16:48:32 +00:00
};
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;
2019-05-24 19:43:57 +00:00
u8 cca_th_40m_bkp; /*@c84[31:28]*/
2018-06-22 16:48:32 +00:00
enum channel_width pre_bw;
u8 pri_cca_is_become_linked;
u8 mf_state;
};
2019-05-24 19:43:57 +00:00
/*@============================================================*/
/*@function prototype*/
/*@============================================================*/
void phydm_write_dynamic_cca(void *dm_void, u8 curr_mf_state);
2018-06-22 16:48:32 +00:00
2019-05-24 19:43:57 +00:00
boolean odm_dynamic_primary_cca_dup_rts(void *dm_void);
2018-06-22 16:48:32 +00:00
2019-05-24 19:43:57 +00:00
void phydm_primary_cca_init(void *dm_void);
2018-06-22 16:48:32 +00:00
2019-05-24 19:43:57 +00:00
void phydm_primary_cca(void *dm_void);
#endif /*@#ifdef PHYDM_PRIMARY_CCA*/
#endif /*@#ifndef __PHYDM_PRIMARYCCA_H__*/
2018-06-22 16:48:32 +00:00