xref: /wlan-driver/qca-wifi-host-cmn/dp/inc/cdp_txrx_cmn_reg.h (revision 5113495b16420b49004c444715d2daae2066e7dc)
1*5113495bSYour Name /*
2*5113495bSYour Name  * Copyright (c) 2011-2021 The Linux Foundation. All rights reserved.
3*5113495bSYour Name  * Copyright (c) 2021-2023 Qualcomm Innovation Center, Inc. All rights reserved.
4*5113495bSYour Name  *
5*5113495bSYour Name  * Permission to use, copy, modify, and/or distribute this software for
6*5113495bSYour Name  * any purpose with or without fee is hereby granted, provided that the
7*5113495bSYour Name  * above copyright notice and this permission notice appear in all
8*5113495bSYour Name  * copies.
9*5113495bSYour Name  *
10*5113495bSYour Name  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
11*5113495bSYour Name  * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
12*5113495bSYour Name  * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
13*5113495bSYour Name  * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
14*5113495bSYour Name  * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
15*5113495bSYour Name  * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
16*5113495bSYour Name  * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
17*5113495bSYour Name  * PERFORMANCE OF THIS SOFTWARE.
18*5113495bSYour Name  */
19*5113495bSYour Name 
20*5113495bSYour Name  /**
21*5113495bSYour Name  * @file cdp_txrx_cmn.h
22*5113495bSYour Name  * @brief Define the host data path converged API functions
23*5113495bSYour Name  * called by the host control SW and the OS interface module
24*5113495bSYour Name  */
25*5113495bSYour Name #ifndef _CDP_TXRX_CMN_REG_H_
26*5113495bSYour Name #define _CDP_TXRX_CMN_REG_H_
27*5113495bSYour Name 
28*5113495bSYour Name #include "hif_main.h"
29*5113495bSYour Name #include "cdp_txrx_cmn_struct.h"
30*5113495bSYour Name 
31*5113495bSYour Name #define MOB_DRV_LEGACY_DP 0xdeed
32*5113495bSYour Name /* Lithium device IDs */
33*5113495bSYour Name #define LITHIUM_DP		0xfffd
34*5113495bSYour Name /* Beryllium device IDs */
35*5113495bSYour Name #define BERYLLIUM_DP		0xaffe
36*5113495bSYour Name 
37*5113495bSYour Name /* RHINE device IDs */
38*5113495bSYour Name #define RHINE_DP		0xbff0
39*5113495bSYour Name /* Use device IDs for attach in future */
40*5113495bSYour Name 
41*5113495bSYour Name /* enum cdp_arch_type - enum for DP arch type
42*5113495bSYour Name  * CDP_ARCH_TYPE_LI - for lithium
43*5113495bSYour Name  * CDP_ARCH_TYPE_BE - for beryllium
44*5113495bSYour Name  * CDP_ARCH_TYPE_NONE - not supported
45*5113495bSYour Name  */
46*5113495bSYour Name enum cdp_arch_type {
47*5113495bSYour Name 	CDP_ARCH_TYPE_NONE = -1,
48*5113495bSYour Name 	CDP_ARCH_TYPE_LI,
49*5113495bSYour Name 	CDP_ARCH_TYPE_BE,
50*5113495bSYour Name 	CDP_ARCH_TYPE_RH,
51*5113495bSYour Name };
52*5113495bSYour Name 
53*5113495bSYour Name #if defined(DP_TXRX_SOC_ATTACH)
54*5113495bSYour Name static inline ol_txrx_soc_handle
ol_txrx_soc_attach(void * scn_handle,struct ol_if_ops * dp_ol_if_ops)55*5113495bSYour Name ol_txrx_soc_attach(void *scn_handle, struct ol_if_ops *dp_ol_if_ops)
56*5113495bSYour Name {
57*5113495bSYour Name 	return NULL;
58*5113495bSYour Name }
59*5113495bSYour Name #else
60*5113495bSYour Name ol_txrx_soc_handle
61*5113495bSYour Name ol_txrx_soc_attach(void *scn_handle, struct ol_if_ops *dp_ol_if_ops);
62*5113495bSYour Name #endif
63*5113495bSYour Name 
64*5113495bSYour Name #if defined(QCA_WIFI_QCA8074) || defined(QCA_WIFI_QCA6018) || \
65*5113495bSYour Name 	defined(QCA_WIFI_QCA5018) || defined(QCA_WIFI_QCA9574) || \
66*5113495bSYour Name 	defined(QCA_WIFI_QCA5332)
67*5113495bSYour Name 
68*5113495bSYour Name /**
69*5113495bSYour Name  * dp_soc_attach_wifi3() - Attach txrx SOC
70*5113495bSYour Name  * @ctrl_psoc:	Opaque SOC handle from Ctrl plane
71*5113495bSYour Name  * @params: soc attach params
72*5113495bSYour Name  *
73*5113495bSYour Name  * Return: DP SOC handle on success, NULL on failure
74*5113495bSYour Name  */
75*5113495bSYour Name struct cdp_soc_t *
76*5113495bSYour Name dp_soc_attach_wifi3(struct cdp_ctrl_objmgr_psoc *ctrl_psoc,
77*5113495bSYour Name 		    struct cdp_soc_attach_params *params);
78*5113495bSYour Name 
79*5113495bSYour Name /**
80*5113495bSYour Name  * dp_soc_init_wifi3() - Initialize txrx SOC
81*5113495bSYour Name  * @soc: Opaque DP SOC handle
82*5113495bSYour Name  * @ctrl_psoc: Opaque SOC handle from control plane
83*5113495bSYour Name  * @hif_handle: Opaque HIF handle
84*5113495bSYour Name  * @htc_handle: Opaque HTC handle
85*5113495bSYour Name  * @qdf_osdev: QDF device
86*5113495bSYour Name  * @ol_ops: Offload Operations
87*5113495bSYour Name  * @device_id: Device ID
88*5113495bSYour Name  *
89*5113495bSYour Name  * Return: DP SOC handle on success, NULL on failure
90*5113495bSYour Name  */
91*5113495bSYour Name void *dp_soc_init_wifi3(struct cdp_soc_t *soc,
92*5113495bSYour Name 			struct cdp_ctrl_objmgr_psoc *ctrl_psoc,
93*5113495bSYour Name 			struct hif_opaque_softc *hif_handle,
94*5113495bSYour Name 			HTC_HANDLE htc_handle, qdf_device_t qdf_osdev,
95*5113495bSYour Name 			struct ol_if_ops *ol_ops, uint16_t device_id);
96*5113495bSYour Name #else
97*5113495bSYour Name static inline struct cdp_soc_t *
dp_soc_attach_wifi3(struct cdp_ctrl_objmgr_psoc * ctrl_psoc,struct cdp_soc_attach_params * params)98*5113495bSYour Name dp_soc_attach_wifi3(struct cdp_ctrl_objmgr_psoc *ctrl_psoc,
99*5113495bSYour Name 		    struct cdp_soc_attach_params *params)
100*5113495bSYour Name {
101*5113495bSYour Name 	return NULL;
102*5113495bSYour Name }
103*5113495bSYour Name 
104*5113495bSYour Name static inline
dp_soc_init_wifi3(struct cdp_soc_t * soc,struct cdp_ctrl_objmgr_psoc * ctrl_psoc,struct hif_opaque_softc * hif_handle,HTC_HANDLE htc_handle,qdf_device_t qdf_osdev,struct ol_if_ops * ol_ops,uint16_t device_id)105*5113495bSYour Name void *dp_soc_init_wifi3(struct cdp_soc_t *soc,
106*5113495bSYour Name 			struct cdp_ctrl_objmgr_psoc *ctrl_psoc,
107*5113495bSYour Name 			struct hif_opaque_softc *hif_handle,
108*5113495bSYour Name 			HTC_HANDLE htc_handle, qdf_device_t qdf_osdev,
109*5113495bSYour Name 			struct ol_if_ops *ol_ops, uint16_t device_id)
110*5113495bSYour Name {
111*5113495bSYour Name 	return NULL;
112*5113495bSYour Name }
113*5113495bSYour Name #endif /* QCA_WIFI_QCA8074 */
114*5113495bSYour Name 
cdp_get_arch_type_from_devid(uint16_t devid)115*5113495bSYour Name static inline int cdp_get_arch_type_from_devid(uint16_t devid)
116*5113495bSYour Name {
117*5113495bSYour Name 	switch (devid) {
118*5113495bSYour Name 	case LITHIUM_DP: /*FIXME Add lithium device IDs */
119*5113495bSYour Name 	case QCA8074_DEVICE_ID: /* Hawekeye */
120*5113495bSYour Name 	case QCA8074V2_DEVICE_ID: /* Hawekeye V2*/
121*5113495bSYour Name 	case QCA9574_DEVICE_ID:
122*5113495bSYour Name 	case QCA5018_DEVICE_ID:
123*5113495bSYour Name 	case QCA6290_DEVICE_ID:
124*5113495bSYour Name 	case QCN9000_DEVICE_ID:
125*5113495bSYour Name 	case QCN6122_DEVICE_ID:
126*5113495bSYour Name 	case QCN9160_DEVICE_ID:
127*5113495bSYour Name 	case QCA6390_DEVICE_ID:
128*5113495bSYour Name 	case QCA6490_DEVICE_ID:
129*5113495bSYour Name 	case QCA6750_DEVICE_ID:
130*5113495bSYour Name 	case QCA6390_EMULATION_DEVICE_ID:
131*5113495bSYour Name 	case RUMIM2M_DEVICE_ID_NODE0: /*lithium emulation */
132*5113495bSYour Name 	case RUMIM2M_DEVICE_ID_NODE1: /*lithium emulation */
133*5113495bSYour Name 	case RUMIM2M_DEVICE_ID_NODE2: /*lithium emulation */
134*5113495bSYour Name 	case RUMIM2M_DEVICE_ID_NODE3: /*lithium emulation */
135*5113495bSYour Name 	case RUMIM2M_DEVICE_ID_NODE4: /*lithium emulation */
136*5113495bSYour Name 	case RUMIM2M_DEVICE_ID_NODE5: /*lithium emulation */
137*5113495bSYour Name 		return CDP_ARCH_TYPE_LI;
138*5113495bSYour Name 	case BERYLLIUM_DP:
139*5113495bSYour Name 	case KIWI_DEVICE_ID:
140*5113495bSYour Name 	case QCN9224_DEVICE_ID:
141*5113495bSYour Name 	case QCA5332_DEVICE_ID:
142*5113495bSYour Name 	case MANGO_DEVICE_ID:
143*5113495bSYour Name 	case PEACH_DEVICE_ID:
144*5113495bSYour Name 	case QCN6432_DEVICE_ID:
145*5113495bSYour Name 		return CDP_ARCH_TYPE_BE;
146*5113495bSYour Name 	case RHINE_DP:
147*5113495bSYour Name 		return CDP_ARCH_TYPE_RH;
148*5113495bSYour Name 	default:
149*5113495bSYour Name 		return CDP_ARCH_TYPE_NONE;
150*5113495bSYour Name 	}
151*5113495bSYour Name }
152*5113495bSYour Name 
153*5113495bSYour Name static inline
cdp_soc_attach(u_int16_t devid,struct hif_opaque_softc * hif_handle,struct cdp_ctrl_objmgr_psoc * psoc,HTC_HANDLE htc_handle,qdf_device_t qdf_dev,struct ol_if_ops * dp_ol_if_ops)154*5113495bSYour Name ol_txrx_soc_handle cdp_soc_attach(u_int16_t devid,
155*5113495bSYour Name 				  struct hif_opaque_softc *hif_handle,
156*5113495bSYour Name 				  struct cdp_ctrl_objmgr_psoc *psoc,
157*5113495bSYour Name 				  HTC_HANDLE htc_handle,
158*5113495bSYour Name 				  qdf_device_t qdf_dev,
159*5113495bSYour Name 				  struct ol_if_ops *dp_ol_if_ops)
160*5113495bSYour Name {
161*5113495bSYour Name 	struct cdp_soc_attach_params params = {0};
162*5113495bSYour Name 
163*5113495bSYour Name 	params.hif_handle = hif_handle;
164*5113495bSYour Name 	params.device_id = devid;
165*5113495bSYour Name 	params.htc_handle = htc_handle;
166*5113495bSYour Name 	params.qdf_osdev = qdf_dev;
167*5113495bSYour Name 	params.ol_ops = dp_ol_if_ops;
168*5113495bSYour Name 
169*5113495bSYour Name 	switch (devid) {
170*5113495bSYour Name 	case LITHIUM_DP: /*FIXME Add lithium device IDs */
171*5113495bSYour Name 	case BERYLLIUM_DP:
172*5113495bSYour Name 	case RHINE_DP:
173*5113495bSYour Name 	case QCA8074_DEVICE_ID: /* Hawekeye */
174*5113495bSYour Name 	case QCA8074V2_DEVICE_ID: /* Hawekeye V2*/
175*5113495bSYour Name 	case QCA5018_DEVICE_ID:
176*5113495bSYour Name 	case QCA6290_DEVICE_ID:
177*5113495bSYour Name 	case QCN9000_DEVICE_ID:
178*5113495bSYour Name 	case QCN6122_DEVICE_ID:
179*5113495bSYour Name 	case QCN9160_DEVICE_ID:
180*5113495bSYour Name 	case QCN6432_DEVICE_ID:
181*5113495bSYour Name 	case QCA6390_DEVICE_ID:
182*5113495bSYour Name 	case QCA6490_DEVICE_ID:
183*5113495bSYour Name 	case QCA6750_DEVICE_ID:
184*5113495bSYour Name 	case QCA6390_EMULATION_DEVICE_ID:
185*5113495bSYour Name 	case RUMIM2M_DEVICE_ID_NODE0: /*lithium emulation */
186*5113495bSYour Name 	case RUMIM2M_DEVICE_ID_NODE1: /*lithium emulation */
187*5113495bSYour Name 	case RUMIM2M_DEVICE_ID_NODE2: /*lithium emulation */
188*5113495bSYour Name 	case RUMIM2M_DEVICE_ID_NODE3: /*lithium emulation */
189*5113495bSYour Name 	case RUMIM2M_DEVICE_ID_NODE4: /*lithium emulation */
190*5113495bSYour Name 	case RUMIM2M_DEVICE_ID_NODE5: /*lithium emulation */
191*5113495bSYour Name 	case KIWI_DEVICE_ID:
192*5113495bSYour Name 	case QCN9224_DEVICE_ID:
193*5113495bSYour Name 	case MANGO_DEVICE_ID:
194*5113495bSYour Name 	case PEACH_DEVICE_ID:
195*5113495bSYour Name 	case QCA5332_DEVICE_ID:
196*5113495bSYour Name 		return dp_soc_attach_wifi3(psoc, &params);
197*5113495bSYour Name 	break;
198*5113495bSYour Name 	default:
199*5113495bSYour Name 		return ol_txrx_soc_attach(psoc, dp_ol_if_ops);
200*5113495bSYour Name 	}
201*5113495bSYour Name 	return NULL;
202*5113495bSYour Name }
203*5113495bSYour Name 
204*5113495bSYour Name #endif /*_CDP_TXRX_CMN_REG_H_ */
205