1 /*
2  * Copyright (c) 2021-2023 Qualcomm Innovation Center, Inc. All rights reserved.
3  *
4  * Permission to use, copy, modify, and/or distribute this software for any
5  * purpose with or without fee is hereby granted, provided that the above
6  * copyright notice and this permission notice appear in all copies.
7  *
8  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
9  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
10  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
11  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
12  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
13  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
14  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
15  */
16 #ifndef __DP_MLO_H
17 #define __DP_MLO_H
18 
19 #include <dp_types.h>
20 #include <dp_peer.h>
21 
22 /* Max number of chips that can participate in MLO */
23 #define DP_MAX_MLO_CHIPS WLAN_MAX_MLO_CHIPS
24 
25 /* Max number of peers supported */
26 #define DP_MAX_MLO_PEER 512
27 
28 /* Max number of chips supported */
29 #define DP_MLO_MAX_DEST_CHIP_ID 4
30 
31 /*
32  * NB: intentionally not using kernel-doc comment because the kernel-doc
33  *     script does not handle the TAILQ_HEAD macro
34  * struct dp_mlo_ctxt - datapath MLO context
35  *
36  * @ctrl_ctxt: opaque handle of cp mlo mgr
37  * @ml_soc_list: list of socs which are mlo enabled. This also maintains
38  *               mlo_chip_id to dp_soc mapping
39  * @ml_soc_cnt: number of SOCs
40  * @ml_soc_list_lock: lock to protect ml_soc_list
41  * @mld_peer_hash: peer hash table for ML peers
42  *           Associated peer with this MAC address)
43  * @mld_peer_hash_lock: lock to protect mld_peer_hash
44  * @toeplitz_hash_ipv4:
45  * @toeplitz_hash_ipv6:
46  * @link_to_pdev_map: link to pdev mapping
47  * @rx_fst: pointer to rx_fst handle
48  * @rx_fst_ref_cnt: ref count of rx_fst
49  * @grp_umac_reset_ctx: UMAC reset context at mlo group level
50  * @mlo_dev_list: list of MLO device context
51  * @mlo_dev_list_lock: lock to protect MLO device ctxt
52  */
53 struct dp_mlo_ctxt {
54 	struct cdp_ctrl_mlo_mgr *ctrl_ctxt;
55 	struct dp_soc *ml_soc_list[DP_MAX_MLO_CHIPS];
56 	uint8_t ml_soc_cnt;
57 	qdf_spinlock_t ml_soc_list_lock;
58 	struct {
59 		uint32_t mask;
60 		uint32_t idx_bits;
61 
62 		TAILQ_HEAD(, dp_peer) * bins;
63 	} mld_peer_hash;
64 
65 	qdf_spinlock_t mld_peer_hash_lock;
66 	uint32_t toeplitz_hash_ipv4[LRO_IPV4_SEED_ARR_SZ];
67 	uint32_t toeplitz_hash_ipv6[LRO_IPV6_SEED_ARR_SZ];
68 	struct dp_pdev_be *link_to_pdev_map[WLAN_MAX_MLO_CHIPS *
69 		WLAN_MAX_MLO_LINKS_PER_SOC];
70 #ifdef DP_UMAC_HW_RESET_SUPPORT
71 	struct dp_soc_mlo_umac_reset_ctx grp_umac_reset_ctx;
72 #endif
73 	/* MLO device ctxt list */
74 	TAILQ_HEAD(, dp_mlo_dev_ctxt) mlo_dev_list;
75 	qdf_spinlock_t mlo_dev_list_lock;
76 };
77 
78 /**
79  * dp_mlo_ctx_to_cdp() - typecast dp mlo context to CDP context
80  * @mlo_ctxt: DP MLO context
81  *
82  * Return: struct cdp_mlo_ctxt pointer
83  */
84 static inline
dp_mlo_ctx_to_cdp(struct dp_mlo_ctxt * mlo_ctxt)85 struct cdp_mlo_ctxt *dp_mlo_ctx_to_cdp(struct dp_mlo_ctxt *mlo_ctxt)
86 {
87 	return (struct cdp_mlo_ctxt *)mlo_ctxt;
88 }
89 
90 /**
91  * cdp_mlo_ctx_to_dp() - typecast CDP MLO context to DP MLO context
92  * @mlo_ctxt: CDP MLO context
93  *
94  * Return: struct dp_soc pointer
95  */
96 static inline
cdp_mlo_ctx_to_dp(struct cdp_mlo_ctxt * mlo_ctxt)97 struct dp_mlo_ctxt *cdp_mlo_ctx_to_dp(struct cdp_mlo_ctxt *mlo_ctxt)
98 {
99 	return (struct dp_mlo_ctxt *)mlo_ctxt;
100 }
101 
102 /**
103  * dp_soc_mlo_fill_params() - update SOC mlo params
104  * @soc: DP soc
105  * @params: soc attach params
106  *
107  * Return: struct dp_soc pointer
108  */
109 void dp_soc_mlo_fill_params(struct dp_soc *soc,
110 			    struct cdp_soc_attach_params *params);
111 
112 /**
113  * dp_pdev_mlo_fill_params() - update PDEV mlo params
114  * @pdev: DP PDEV
115  * @params: PDEV attach params
116  *
117  * Return: struct dp_soc pointer
118  */
119 void dp_pdev_mlo_fill_params(struct dp_pdev *pdev,
120 			     struct cdp_pdev_attach_params *params);
121 
122 /**
123  * dp_mlo_get_soc_ref_by_chip_id() - Get DP soc from DP ML context.
124  * @ml_ctxt: DP ML context handle
125  * @chip_id: MLO chip id
126  *
127  * This API will increment a reference count for DP soc. Caller has
128  * to take care for decrementing refcount.
129  *
130  * Return: dp_soc
131  */
132 struct dp_soc*
133 dp_mlo_get_soc_ref_by_chip_id(struct dp_mlo_ctxt *ml_ctxt, uint8_t chip_id);
134 
135 /**
136  * dp_mlo_get_rx_hash_key() - Get Rx hash key from MLO context
137  * @soc: DP SOC
138  * @lro_hash: Hash params
139  *
140  */
141 void dp_mlo_get_rx_hash_key(struct dp_soc *soc,
142 			    struct cdp_lro_hash_config *lro_hash);
143 
144 /**
145  * dp_mlo_rx_fst_deref() - decrement rx_fst
146  * @soc: dp soc
147  *
148  * return: soc cnt
149  */
150 uint8_t dp_mlo_rx_fst_deref(struct dp_soc *soc);
151 
152 /**
153  * dp_mlo_rx_fst_ref() - increment ref of rx_fst
154  * @soc: dp soc
155  *
156  */
157 void dp_mlo_rx_fst_ref(struct dp_soc *soc);
158 
159 /**
160  * dp_mlo_get_rx_fst() - Get Rx FST from MLO context
161  * @soc: DP SOC
162  *
163  * Return: struct dp_rx_fst pointer
164  */
165 struct dp_rx_fst *dp_mlo_get_rx_fst(struct dp_soc *soc);
166 
167 /**
168  * dp_mlo_set_rx_fst() - Set Rx FST in MLO context
169  * @soc: DP SOC
170  * @fst: pointer dp_rx_fst
171  *
172  */
173 void dp_mlo_set_rx_fst(struct dp_soc *soc, struct dp_rx_fst *fst);
174 
175 /**
176  * dp_mlo_update_link_to_pdev_map() - map link-id to pdev mapping
177  * @soc: DP SOC
178  * @pdev: DP PDEV
179  *
180  * Return: none
181  */
182 void dp_mlo_update_link_to_pdev_map(struct dp_soc *soc, struct dp_pdev *pdev);
183 
184 /**
185  * dp_mlo_update_link_to_pdev_unmap() - unmap link-id to pdev mapping
186  * @soc: DP SOC
187  * @pdev: DP PDEV
188  *
189  * Return: none
190  */
191 void dp_mlo_update_link_to_pdev_unmap(struct dp_soc *soc, struct dp_pdev *pdev);
192 
193 /**
194  * dp_mlo_get_delta_tsf2_wrt_mlo_offset() - Get delta between mlo timestamp
195  *                                          offset and delta tsf2
196  * @soc: DP SOC
197  * @hw_link_id: link id
198  *
199  * Return: int32_t
200  */
201 int32_t dp_mlo_get_delta_tsf2_wrt_mlo_offset(struct dp_soc *soc,
202 					     uint8_t hw_link_id);
203 
204 /**
205  * dp_mlo_get_delta_tqm_wrt_mlo_offset() - Get delta between mlo timestamp
206  *                                         offset and delta tqm
207  * @soc: DP SOC
208  *
209  * Return: int32_t
210  */
211 int32_t dp_mlo_get_delta_tqm_wrt_mlo_offset(struct dp_soc *soc);
212 
213 /**
214  * dp_get_interface_stats_be() - get vdev stats for ath interface
215  * @soc_hdl: CDP SoC handle
216  * @vdev_id: vdev Id
217  * @buf: buffer for vdev stats
218  * @is_aggregate: for aggregation
219  *
220  * Return: QDF_STATUS
221  */
222 QDF_STATUS
223 dp_get_interface_stats_be(struct cdp_soc_t *soc_hdl, uint8_t vdev_id,
224 			  void *buf, bool is_aggregate);
225 
226 /*
227  * dp_mlo_debug_print_ptnr_info() - print partner info
228  * @vdev: DP VDEV
229  *
230  * Return: none
231  */
232 void dp_mlo_debug_print_ptnr_info(struct dp_vdev *vdev);
233 
234 /*
235  * dp_mlo_get_chip_id() - return MLO chip id
236  * @soc: DP soc
237  *
238  * Return: chip_id
239  */
240 uint8_t dp_mlo_get_chip_id(struct dp_soc *soc);
241 
242 /*
243  * dp_mlo_link_peer_hash_find_by_chip_id() - returns mlo link peer on chip_id
244  *			      peer_hash_table matching vdev_id and mac_address
245  * @soc: partner soc handle in MLO
246  * @peer_mac_addr: peer mac address
247  * @mac_addr_is_aligned: is mac addr aligned
248  * @vdev_id: vdev_id
249  * @chip_id: mlo_chip_id
250  * @mod_id: id of module requesting reference
251  *
252  * return: peer in success
253  *         NULL in failure
254  */
255 struct dp_peer *
256 dp_mlo_link_peer_hash_find_by_chip_id(struct dp_soc *soc,
257 				      uint8_t *peer_mac_addr,
258 				      int mac_addr_is_aligned,
259 				      uint8_t vdev_id,
260 				      uint8_t chip_id,
261 				      enum dp_mod_id mod_id);
262 #endif /* __DP_MLO_H */
263