hc
2024-12-19 9370bb92b2d16684ee45cf24e879c93c509162da
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
/******************************************************************************
 *
 * Copyright(c) 2019 - 2023 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 _HAL_PCI_H_
#define _HAL_PCI_H_
 
#ifdef CONFIG_PCI_HCI
void hal_pci_set_io_ops(struct rtw_hal_com_t *hal, struct hal_io_ops *pops);
 
#ifdef CONFIG_RTL8851B
#include "rtl8851b/rtl8851b.h"
#endif
 
#ifdef CONFIG_RTL8852A
#include "rtl8852a/rtl8852a.h"
#endif
 
#if defined(CONFIG_RTL8852B) || defined(CONFIG_RTL8852BP) || defined(CONFIG_RTL8852BT)
#include "rtl8852b/rtl8852b.h"
#endif
 
#ifdef CONFIG_RTL8852C
#include "rtl8852c/rtl8852c.h"
#endif
 
#ifdef CONFIG_RTL8852D
#include "rtl8852d/rtl8852d.h"
#endif
 
#if defined(CONFIG_RTL8832BR) || defined(CONFIG_RTL8192XB)
#include "rtl8192xb/rtl8192xb.h"
#endif
 
/* Times to polling RX DMA finish tag in RXBD info */
#ifndef PHL_DMA_NONCOHERENT
#define RX_TAG_POLLING_TIMES    (10000)
#else /* PHL_DMA_NONCOHERENT */
/* Cache handling for coherence takes time. Polling less */
#define RX_TAG_POLLING_TIMES    (100)
#endif /* PHL_DMA_NONCOHERENT */
 
static inline void hal_set_ops_pci(struct rtw_phl_com_t *phl_com,
                   struct hal_info_t *hal)
{
#ifdef CONFIG_RTL8852A
   if (hal_get_chip_id(hal->hal_com) == CHIP_WIFI6_8852A) {
       hal_set_ops_8852ae(phl_com, hal);
       hal_hook_trx_ops_8852ae(phl_com, hal);
   }
#endif
 
#if defined(CONFIG_RTL8852B) || defined(CONFIG_RTL8852BP) || defined(CONFIG_RTL8852BT)
   if (hal_get_chip_id(hal->hal_com) == CHIP_WIFI6_8852B ||
       hal_get_chip_id(hal->hal_com) == CHIP_WIFI6_8852BP ||
       hal_get_chip_id(hal->hal_com) == CHIP_WIFI6_8852BT) {
       hal_set_ops_8852be(phl_com, hal);
       hal_hook_trx_ops_8852be(phl_com, hal);
   }
#endif
 
#ifdef CONFIG_RTL8852C
   if (hal_get_chip_id(hal->hal_com) == CHIP_WIFI6_8852C) {
       hal_set_ops_8852ce(phl_com, hal);
       hal_hook_trx_ops_8852ce(phl_com, hal);
   }
#endif
 
#ifdef CONFIG_RTL8852D
   if (hal_get_chip_id(hal->hal_com) == CHIP_WIFI6_8852D) {
       hal_set_ops_8852de(phl_com, hal);
       hal_hook_trx_ops_8852de(phl_com, hal);
   }
#endif
 
#ifdef CONFIG_RTL8851B
   if (hal_get_chip_id(hal->hal_com) == CHIP_WIFI6_8851B) {
       hal_set_ops_8851be(phl_com, hal);
       hal_hook_trx_ops_8851be(phl_com, hal);
   }
#endif
 
#if defined(CONFIG_RTL8832BR) || defined(CONFIG_RTL8192XB)
   if (hal_get_chip_id(hal->hal_com) == CHIP_WIFI6_8192XB ||
       hal_get_chip_id(hal->hal_com) == CHIP_WIFI6_8832BR) {
       hal_set_ops_8192xbe(phl_com, hal);
       hal_hook_trx_ops_8192xbe(phl_com, hal);
   }
#endif
 
   /*
   else if (hal_get_chip_id(hal->hal_com) == CHIP_WIFI6_8834A)
       rtl8834ae_set_hal_ops(hal);
   else if (hal_get_chip_id(hal->hal_com) == CHIP_WIFI6_8852B)
       rtl8852be_set_hal_ops(hal);
   */
}
#endif /*CONFIG_PCI_HCI*/
#endif /*_HAL_PCI_H_*/