hc
2024-05-08 f309769f8af08599af39b6de4f675784ce76530d
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
/******************************************************************************
 *
 * Copyright(c) 2016 - 2019 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.
 *
 ******************************************************************************/
 
#ifndef _HALMAC_PCIE_88XX_H_
#define _HALMAC_PCIE_88XX_H_
 
#include "../halmac_api.h"
 
#if (HALMAC_88XX_SUPPORT && HALMAC_PCIE_SUPPORT)
 
enum halmac_ret_status
init_pcie_cfg_88xx(struct halmac_adapter *adapter);
 
enum halmac_ret_status
deinit_pcie_cfg_88xx(struct halmac_adapter *adapter);
 
enum halmac_ret_status
cfg_pcie_rx_agg_88xx(struct halmac_adapter *adapter,
            struct halmac_rxagg_cfg *cfg);
 
u8
reg_r8_pcie_88xx(struct halmac_adapter *adapter, u32 offset);
 
enum halmac_ret_status
reg_w8_pcie_88xx(struct halmac_adapter *adapter, u32 offset, u8 value);
 
u16
reg_r16_pcie_88xx(struct halmac_adapter *adapter, u32 offset);
 
enum halmac_ret_status
reg_w16_pcie_88xx(struct halmac_adapter *adapter, u32 offset, u16 value);
 
u32
reg_r32_pcie_88xx(struct halmac_adapter *adapter, u32 offset);
 
enum halmac_ret_status
reg_w32_pcie_88xx(struct halmac_adapter *adapter, u32 offset, u32 value);
 
enum halmac_ret_status
cfg_txagg_pcie_align_88xx(struct halmac_adapter *adapter, u8 enable,
             u16 align_size);
 
enum halmac_ret_status
tx_allowed_pcie_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size);
 
u32
pcie_indirect_reg_r32_88xx(struct halmac_adapter *adapter, u32 offset);
 
enum halmac_ret_status
pcie_reg_rn_88xx(struct halmac_adapter *adapter, u32 offset, u32 size,
        u8 *value);
 
enum halmac_ret_status
set_pcie_bulkout_num_88xx(struct halmac_adapter *adapter, u8 num);
 
enum halmac_ret_status
get_pcie_tx_addr_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size,
             u32 *cmd53_addr);
 
enum halmac_ret_status
get_pcie_bulkout_id_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size,
            u8 *id);
 
enum halmac_ret_status
mdio_write_88xx(struct halmac_adapter *adapter, u8 addr, u16 data, u8 speed);
 
u16
mdio_read_88xx(struct halmac_adapter *adapter, u8 addr, u8 speed);
 
enum halmac_ret_status
dbi_w32_88xx(struct halmac_adapter *adapter, u16 addr, u32 data);
 
u32
dbi_r32_88xx(struct halmac_adapter *adapter, u16 addr);
 
enum halmac_ret_status
dbi_w8_88xx(struct halmac_adapter *adapter, u16 addr, u8 data);
 
u8
dbi_r8_88xx(struct halmac_adapter *adapter, u16 addr);
 
enum halmac_ret_status
trxdma_check_idle_88xx(struct halmac_adapter *adapter);
 
enum halmac_ret_status
en_ref_autok_pcie_88xx(struct halmac_adapter *dapter, u8 en);
 
#endif /* HALMAC_88XX_SUPPORT */
 
#endif/* _HALMAC_PCIE_88XX_H_ */