SAMA5D4 Xplained Ultra Board BSP
guowenxue
2019-08-19 2e7235d10c6dbff81960282e1a1e2e798f9b8db8
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
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
/******************************************************************************
 *
 * 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 __INC_HAL8814PHYCFG_H__
#define __INC_HAL8814PHYCFG_H__
 
 
/*--------------------------Define Parameters-------------------------------*/
#define LOOP_LIMIT                5
#define MAX_STALL_TIME            50        /* us */
#define AntennaDiversityValue    0x80    /* (Adapter->bSoftwareAntennaDiversity ? 0x00 : 0x80) */
#define MAX_TXPWR_IDX_NMODE_92S    63
#define Reset_Cnt_Limit            3
 
 
#ifdef CONFIG_PCI_HCI
    #define MAX_AGGR_NUM    0x0B
#else
    #define MAX_AGGR_NUM    0x07
#endif /* CONFIG_PCI_HCI */
 
 
/*--------------------------Define Parameters-------------------------------*/
 
/*------------------------------Define structure----------------------------*/
 
 
/* BB/RF related */
 
#define    SIC_ENABLE                0
 
/*------------------------------Define structure----------------------------*/
 
 
/*------------------------Export global variable----------------------------*/
/*------------------------Export global variable----------------------------*/
 
 
/*------------------------Export Marco Definition---------------------------*/
/*------------------------Export Marco Definition---------------------------*/
 
 
/*--------------------------Exported Function prototype---------------------*/
/* 1. BB register R/W API */
 
extern    u32
PHY_QueryBBReg8814A(IN    PADAPTER    Adapter,
            IN    u32        RegAddr,
            IN    u32        BitMask);
 
 
VOID
PHY_SetBBReg8814A(IN    PADAPTER    Adapter,
          IN    u32        RegAddr,
          IN    u32        BitMask,
          IN    u32        Data);
 
 
extern    u32
PHY_QueryRFReg8814A(IN    PADAPTER            Adapter,
            IN    u8            eRFPath,
            IN    u32            RegAddr,
            IN    u32            BitMask);
 
 
void
PHY_SetRFReg8814A(IN    PADAPTER            Adapter,
          IN    u8            eRFPath,
          IN    u32                RegAddr,
          IN    u32                BitMask,
          IN    u32                Data);
 
/* 1 3. Initial BB/RF config by reading MAC/BB/RF txt. */
s32
phy_BB8814A_Config_ParaFile(
    IN    PADAPTER    Adapter
);
 
VOID
PHY_ConfigBB_8814A(
    IN    PADAPTER    Adapter
);
 
 
VOID
phy_ADC_CLK_8814A(
    IN    PADAPTER    Adapter
);
 
s32
PHY_RFConfig8814A(
    IN    PADAPTER    Adapter
);
 
/*
 * RF Power setting
 *
 * BOOLEAN    PHY_SetRFPowerState8814A(PADAPTER Adapter, rt_rf_power_state    eRFPowerState); */
 
/* 1 5. Tx  Power setting API */
 
VOID
PHY_GetTxPowerLevel8814(
    IN    PADAPTER        Adapter,
    OUT ps4Byte            powerlevel
);
 
VOID
PHY_SetTxPowerLevel8814(
    IN    PADAPTER        Adapter,
    IN    u8            Channel
);
 
u8
phy_get_tx_power_index_8814a(
    IN    PADAPTER            Adapter,
    IN  u8                RFPath,
    IN    u8                Rate,
    IN    CHANNEL_WIDTH        BandWidth,
    IN    u8                Channel
);
 
u8
PHY_GetTxPowerIndex8814A(
    IN    PADAPTER            Adapter,
    IN  u8                RFPath,
    IN    u8                Rate,
    IN    u8                BandWidth,
    IN    u8                Channel,
    struct txpwr_idx_comp *tic
);
 
VOID
PHY_SetTxPowerIndex_8814A(
    IN    PADAPTER            Adapter,
    IN    u32                PowerIndex,
    IN    u8                RFPath,
    IN    u8                Rate
);
 
 
BOOLEAN
PHY_UpdateTxPowerDbm8814A(
    IN    PADAPTER    Adapter,
    IN    s4Byte        powerInDbm
);
 
 
u32
PHY_GetTxBBSwing_8814A(
    IN    PADAPTER    Adapter,
    IN    BAND_TYPE    Band,
    IN    u8        RFPath
);
 
 
 
/* 1 6. Channel setting API */
 
VOID
PHY_SwChnlTimerCallback8814A(
    IN    struct timer_list        *p_timer
);
 
VOID
PHY_SwChnlWorkItemCallback8814A(
    IN PVOID            pContext
);
 
 
VOID
HAL_HandleSwChnl8814A(
    IN    PADAPTER    pAdapter,
    IN    u8        channel
);
 
VOID
PHY_SwChnlSynchronously8814A(IN    PADAPTER        pAdapter,
                 IN    u8            channel);
 
VOID
PHY_SwChnlAndSetBWModeCallback8814A(IN PVOID            pContext);
 
 
VOID
PHY_HandleSwChnlAndSetBW8814A(
    IN    PADAPTER            Adapter,
    IN    BOOLEAN                bSwitchChannel,
    IN    BOOLEAN                bSetBandWidth,
    IN    u8                    ChannelNum,
    IN    CHANNEL_WIDTH        ChnlWidth,
    IN    u8                    ChnlOffsetOf40MHz,
    IN    u8                    ChnlOffsetOf80MHz,
    IN    u8                    CenterFrequencyIndex1
);
 
 
BOOLEAN
PHY_QueryRFPathSwitch_8814A(IN    PADAPTER    pAdapter);
 
 
 
#if (USE_WORKITEM)
VOID
RtCheckForHangWorkItemCallback8814A(
    IN PVOID   pContext
);
#endif
 
BOOLEAN
SetAntennaConfig8814A(
    IN    PADAPTER    Adapter,
    IN    u8        DefaultAnt
);
 
VOID
PHY_SetRFEReg8814A(
    IN PADAPTER        Adapter,
    IN BOOLEAN        bInit,
    IN u8        Band
);
 
 
s32
PHY_SwitchWirelessBand8814A(
    IN PADAPTER         Adapter,
    IN u8        Band
);
 
VOID
PHY_SetIO_8814A(
    PADAPTER        pAdapter
);
 
VOID
PHY_SetSwChnlBWMode8814(
    IN    PADAPTER            Adapter,
    IN    u8                    channel,
    IN    CHANNEL_WIDTH        Bandwidth,
    IN    u8                    Offset40,
    IN    u8                    Offset80
);
 
s32 PHY_MACConfig8814(PADAPTER Adapter);
int PHY_BBConfig8814(PADAPTER    Adapter);
VOID PHY_Set_SecCCATH_by_RXANT_8814A(PADAPTER    pAdapter, u4Byte ulAntennaRx);
 
 
 
/*--------------------------Exported Function prototype---------------------*/
 
/*--------------------------Exported Function prototype---------------------*/
#endif /* __INC_HAL8192CPHYCFG_H */