hc
2023-12-06 08f87f769b595151be1afeff53e144f543faa614
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
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
/* SPDX-License-Identifier: GPL-2.0 */
#ifndef _HALMAC_FUNC_88XX_H_
#define _HALMAC_FUNC_88XX_H_
 
#include "../halmac_type.h"
 
 
HALMAC_RET_STATUS
halmac_send_h2c_pkt_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN u8 *pHal_buff,
   IN u32 size,
   IN u8 ack
);
 
HALMAC_RET_STATUS
halmac_download_rsvd_page_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN u8 *pHal_buf,
   IN u32 size
);
 
HALMAC_RET_STATUS
halmac_set_h2c_header_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   OUT u8 *pHal_h2c_hdr,
   IN u16 *seq,
   IN u8 ack
);
 
HALMAC_RET_STATUS
halmac_set_fw_offload_h2c_header_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   OUT u8 *pHal_h2c_hdr,
   IN PHALMAC_H2C_HEADER_INFO pH2c_header_info,
   OUT u16 *pSeq_num
);
 
HALMAC_RET_STATUS
halmac_dump_efuse_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN HALMAC_EFUSE_READ_CFG cfg
);
 
HALMAC_RET_STATUS
halmac_func_read_efuse_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN u32 offset,
   IN u32 size,
   OUT u8 *pEfuse_map
);
 
HALMAC_RET_STATUS
halmac_func_write_efuse_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN u32 offset,
   IN u8 value
);
 
HALMAC_RET_STATUS
halmac_func_switch_efuse_bank_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN HALMAC_EFUSE_BANK efuse_bank
);
 
HALMAC_RET_STATUS
halmac_read_logical_efuse_map_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN u8 *pMap
);
 
HALMAC_RET_STATUS
halmac_func_write_logical_efuse_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN u32 offset,
   IN u8 value
);
 
HALMAC_RET_STATUS
halmac_func_pg_efuse_by_map_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN PHALMAC_PG_EFUSE_INFO pPg_efuse_info,
   IN HALMAC_EFUSE_READ_CFG cfg
);
 
HALMAC_RET_STATUS
halmac_eeprom_parser_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN u8 *pPhysical_efuse_map,
   OUT u8 *pLogical_efuse_map
);
 
HALMAC_RET_STATUS
halmac_read_hw_efuse_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN u32 offset,
   IN u32 size,
   OUT u8 *pEfuse_map
);
 
HALMAC_RET_STATUS
halmac_dlfw_to_mem_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN u8 *pRam_code,
   IN u32 dest,
   IN u32 code_size
);
 
HALMAC_RET_STATUS
halmac_send_fwpkt_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN u8 *pRam_code,
   IN u32 code_size
);
 
HALMAC_RET_STATUS
halmac_iddma_dlfw_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN u32 source,
   IN u32 dest,
   IN u32 length,
   IN u8 first
);
 
HALMAC_RET_STATUS
halmac_check_fw_chksum_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN u32 memory_address
);
 
HALMAC_RET_STATUS
halmac_dlfw_end_flow_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter
);
 
HALMAC_RET_STATUS
halmac_pwr_seq_parser_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN u8 CUT,
   IN u8 FAB,
   IN u8 INTF,
   IN PHALMAC_WLAN_PWR_CFG PWR_SEQ_CFG
);
 
HALMAC_RET_STATUS
halmac_get_h2c_buff_free_space_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter
);
 
HALMAC_RET_STATUS
halmac_send_h2c_set_pwr_mode_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN PHALMAC_FWLPS_OPTION pHal_FwLps_Opt
);
 
HALMAC_RET_STATUS
halmac_func_send_original_h2c_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN u8 *original_h2c,
   IN u16 *seq,
   IN u8 ack
);
 
HALMAC_RET_STATUS
halmac_media_status_rpt_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN u8 op_mode,
   IN u8 mac_id_ind,
   IN u8 mac_id,
   IN u8 mac_id_end
);
 
HALMAC_RET_STATUS
halmac_send_h2c_update_datapack_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN HALMAC_DATA_TYPE halmac_data_type,
   IN PHALMAC_PHY_PARAMETER_INFO para_info
);
 
HALMAC_RET_STATUS
halmac_send_h2c_run_datapack_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN HALMAC_DATA_TYPE halmac_data_type
);
 
HALMAC_RET_STATUS
halmac_send_bt_coex_cmd_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN u8 *pBt_buf,
   IN u32 bt_size,
   IN u8 ack
);
 
HALMAC_RET_STATUS
halmac_func_ctrl_ch_switch_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN PHALMAC_CH_SWITCH_OPTION pCs_option
);
 
HALMAC_RET_STATUS
halmac_func_send_general_info_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN PHALMAC_GENERAL_INFO pGeneral_info
);
 
HALMAC_RET_STATUS
halmac_send_h2c_ps_tuning_para_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter
);
 
HALMAC_RET_STATUS
halmac_parse_c2h_packet_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN u8 *halmac_buf,
   IN u32 halmac_size
);
 
HALMAC_RET_STATUS
halmac_send_h2c_update_packet_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN HALMAC_PACKET_ID pkt_id,
   IN u8 *pkt,
   IN u32 pkt_size
);
 
HALMAC_RET_STATUS
halmac_send_h2c_phy_parameter_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN PHALMAC_PHY_PARAMETER_INFO para_info,
   IN u8 full_fifo
);
 
HALMAC_RET_STATUS
halmac_dump_physical_efuse_fw_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN u32 offset,
   IN u32 Size,
   OUT u8 *pEfuse_map
);
 
HALMAC_RET_STATUS
halmac_send_h2c_update_bcn_parse_info_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN PHALMAC_BCN_IE_INFO pBcn_ie_info
);
 
HALMAC_RET_STATUS
halmac_convert_to_sdio_bus_offset_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   INOUT u32 *halmac_offset
);
 
HALMAC_RET_STATUS
halmac_update_sdio_free_page_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter
);
 
HALMAC_RET_STATUS
halmac_update_oqt_free_space_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter
);
 
HALMAC_EFUSE_CMD_CONSTRUCT_STATE
halmac_query_efuse_curr_state_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter
);
 
HALMAC_RET_STATUS
halmac_transition_efuse_state_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN HALMAC_EFUSE_CMD_CONSTRUCT_STATE dest_state
);
 
HALMAC_CFG_PARA_CMD_CONSTRUCT_STATE
halmac_query_cfg_para_curr_state_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter
);
 
HALMAC_RET_STATUS
halmac_transition_cfg_para_state_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN HALMAC_CFG_PARA_CMD_CONSTRUCT_STATE dest_state
);
 
HALMAC_SCAN_CMD_CONSTRUCT_STATE
halmac_query_scan_curr_state_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter
);
 
HALMAC_RET_STATUS
halmac_transition_scan_state_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN HALMAC_SCAN_CMD_CONSTRUCT_STATE dest_state
);
 
HALMAC_RET_STATUS
halmac_query_cfg_para_status_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   OUT HALMAC_CMD_PROCESS_STATUS *pProcess_status,
   INOUT u8 *data,
   INOUT u32 *size
);
 
HALMAC_RET_STATUS
halmac_query_dump_physical_efuse_status_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   OUT HALMAC_CMD_PROCESS_STATUS *pProcess_status,
   INOUT u8 *data,
   INOUT u32 *size
);
 
HALMAC_RET_STATUS
halmac_query_dump_logical_efuse_status_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   OUT HALMAC_CMD_PROCESS_STATUS *pProcess_status,
   INOUT u8 *data,
   INOUT u32 *size
);
 
HALMAC_RET_STATUS
halmac_query_channel_switch_status_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   OUT HALMAC_CMD_PROCESS_STATUS *pProcess_status,
   INOUT u8 *data,
   INOUT u32 *size
);
 
HALMAC_RET_STATUS
halmac_query_update_packet_status_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   OUT HALMAC_CMD_PROCESS_STATUS *pProcess_status,
   INOUT u8 *data,
   INOUT u32 *size
);
 
HALMAC_RET_STATUS
halmac_query_iqk_status_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   OUT HALMAC_CMD_PROCESS_STATUS *pProcess_status,
   INOUT u8 *data,
   INOUT u32 *size
);
 
HALMAC_RET_STATUS
halmac_query_power_tracking_status_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   OUT HALMAC_CMD_PROCESS_STATUS *pProcess_status,
   INOUT u8 *data,
   INOUT u32 *size
);
 
HALMAC_RET_STATUS
halmac_query_psd_status_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   OUT HALMAC_CMD_PROCESS_STATUS *pProcess_status,
   INOUT u8 *data,
   INOUT u32 *size
);
 
HALMAC_RET_STATUS
halmac_verify_io_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter
);
 
HALMAC_RET_STATUS
halmac_verify_send_rsvd_page_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter
);
 
VOID
halmac_power_save_cb_88xx(
   IN VOID *CbData
);
 
HALMAC_RET_STATUS
halmac_buffer_read_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN u32 offset,
   IN u32 size,
   IN HAL_FIFO_SEL halmac_fifo_sel,
   OUT u8 *pFifo_map
);
 
VOID
halmac_restore_mac_register_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN PHALMAC_RESTORE_INFO pRestore_info,
   IN u32 restore_num
);
 
VOID
halmac_api_record_id_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN HALMAC_API_ID api_id
);
 
VOID
halmac_get_hcpwm_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   OUT u8 *pHcpwm
);
 
VOID
halmac_get_hcpwm2_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   OUT u16 *pHcpwm2
);
 
VOID
halmac_set_hrpwm_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN u8 hrpwm
);
 
VOID
halmac_set_hrpwm2_88xx(
   IN PHALMAC_ADAPTER pHalmac_adapter,
   IN u16 hrpwm2
);
 
#endif /* _HALMAC_FUNC_88XX_H_ */