hc
2023-11-06 15ade055295d13f95d49e3d99b09f3bbfb4a43e7
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
/******************************************************************************
 *
 * Copyright(c) 2007 - 2017 Realtek Corporation.
 *
 * This program is free software; you can redistribute it and/or modify it
 * under the terms of version 2 of the GNU General Public License as
 * published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful, but WITHOUT
 * ANY 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_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            *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
);
 
void
phydm_primary_cca_init(
   void            *p_dm_void
);
 
void
phydm_primary_cca(
   void            *p_dm_void
);
 
 
#endif /*#ifndef    __PHYDM_PRIMARYCCA_H__*/