xref: /openbmc/linux/drivers/vdpa/mlx5/net/mlx5_vnet.c (revision 8a649e33f48e08be20c51541d9184645892ec370)
1 // SPDX-License-Identifier: GPL-2.0 OR Linux-OpenIB
2 /* Copyright (c) 2020 Mellanox Technologies Ltd. */
3 
4 #include <linux/module.h>
5 #include <linux/vdpa.h>
6 #include <linux/vringh.h>
7 #include <uapi/linux/virtio_net.h>
8 #include <uapi/linux/virtio_ids.h>
9 #include <uapi/linux/vdpa.h>
10 #include <linux/virtio_config.h>
11 #include <linux/auxiliary_bus.h>
12 #include <linux/mlx5/cq.h>
13 #include <linux/mlx5/qp.h>
14 #include <linux/mlx5/device.h>
15 #include <linux/mlx5/driver.h>
16 #include <linux/mlx5/vport.h>
17 #include <linux/mlx5/fs.h>
18 #include <linux/mlx5/mlx5_ifc_vdpa.h>
19 #include <linux/mlx5/mpfs.h>
20 #include "mlx5_vdpa.h"
21 #include "mlx5_vnet.h"
22 
23 MODULE_AUTHOR("Eli Cohen <eli@mellanox.com>");
24 MODULE_DESCRIPTION("Mellanox VDPA driver");
25 MODULE_LICENSE("Dual BSD/GPL");
26 
27 #define VALID_FEATURES_MASK                                                                        \
28 	(BIT_ULL(VIRTIO_NET_F_CSUM) | BIT_ULL(VIRTIO_NET_F_GUEST_CSUM) |                                   \
29 	 BIT_ULL(VIRTIO_NET_F_CTRL_GUEST_OFFLOADS) | BIT_ULL(VIRTIO_NET_F_MTU) | BIT_ULL(VIRTIO_NET_F_MAC) |   \
30 	 BIT_ULL(VIRTIO_NET_F_GUEST_TSO4) | BIT_ULL(VIRTIO_NET_F_GUEST_TSO6) |                             \
31 	 BIT_ULL(VIRTIO_NET_F_GUEST_ECN) | BIT_ULL(VIRTIO_NET_F_GUEST_UFO) | BIT_ULL(VIRTIO_NET_F_HOST_TSO4) | \
32 	 BIT_ULL(VIRTIO_NET_F_HOST_TSO6) | BIT_ULL(VIRTIO_NET_F_HOST_ECN) | BIT_ULL(VIRTIO_NET_F_HOST_UFO) |   \
33 	 BIT_ULL(VIRTIO_NET_F_MRG_RXBUF) | BIT_ULL(VIRTIO_NET_F_STATUS) | BIT_ULL(VIRTIO_NET_F_CTRL_VQ) |      \
34 	 BIT_ULL(VIRTIO_NET_F_CTRL_RX) | BIT_ULL(VIRTIO_NET_F_CTRL_VLAN) |                                 \
35 	 BIT_ULL(VIRTIO_NET_F_CTRL_RX_EXTRA) | BIT_ULL(VIRTIO_NET_F_GUEST_ANNOUNCE) |                      \
36 	 BIT_ULL(VIRTIO_NET_F_MQ) | BIT_ULL(VIRTIO_NET_F_CTRL_MAC_ADDR) | BIT_ULL(VIRTIO_NET_F_HASH_REPORT) |  \
37 	 BIT_ULL(VIRTIO_NET_F_RSS) | BIT_ULL(VIRTIO_NET_F_RSC_EXT) | BIT_ULL(VIRTIO_NET_F_STANDBY) |           \
38 	 BIT_ULL(VIRTIO_NET_F_SPEED_DUPLEX) | BIT_ULL(VIRTIO_F_NOTIFY_ON_EMPTY) |                          \
39 	 BIT_ULL(VIRTIO_F_ANY_LAYOUT) | BIT_ULL(VIRTIO_F_VERSION_1) | BIT_ULL(VIRTIO_F_ACCESS_PLATFORM) |      \
40 	 BIT_ULL(VIRTIO_F_RING_PACKED) | BIT_ULL(VIRTIO_F_ORDER_PLATFORM) | BIT_ULL(VIRTIO_F_SR_IOV))
41 
42 #define VALID_STATUS_MASK                                                                          \
43 	(VIRTIO_CONFIG_S_ACKNOWLEDGE | VIRTIO_CONFIG_S_DRIVER | VIRTIO_CONFIG_S_DRIVER_OK |        \
44 	 VIRTIO_CONFIG_S_FEATURES_OK | VIRTIO_CONFIG_S_NEEDS_RESET | VIRTIO_CONFIG_S_FAILED)
45 
46 #define MLX5_FEATURE(_mvdev, _feature) (!!((_mvdev)->actual_features & BIT_ULL(_feature)))
47 
48 #define MLX5V_UNTAGGED 0x1000
49 
50 struct mlx5_vdpa_cq_buf {
51 	struct mlx5_frag_buf_ctrl fbc;
52 	struct mlx5_frag_buf frag_buf;
53 	int cqe_size;
54 	int nent;
55 };
56 
57 struct mlx5_vdpa_cq {
58 	struct mlx5_core_cq mcq;
59 	struct mlx5_vdpa_cq_buf buf;
60 	struct mlx5_db db;
61 	int cqe;
62 };
63 
64 struct mlx5_vdpa_umem {
65 	struct mlx5_frag_buf_ctrl fbc;
66 	struct mlx5_frag_buf frag_buf;
67 	int size;
68 	u32 id;
69 };
70 
71 struct mlx5_vdpa_qp {
72 	struct mlx5_core_qp mqp;
73 	struct mlx5_frag_buf frag_buf;
74 	struct mlx5_db db;
75 	u16 head;
76 	bool fw;
77 };
78 
79 struct mlx5_vq_restore_info {
80 	u32 num_ent;
81 	u64 desc_addr;
82 	u64 device_addr;
83 	u64 driver_addr;
84 	u16 avail_index;
85 	u16 used_index;
86 	bool ready;
87 	bool restore;
88 };
89 
90 struct mlx5_vdpa_virtqueue {
91 	bool ready;
92 	u64 desc_addr;
93 	u64 device_addr;
94 	u64 driver_addr;
95 	u32 num_ent;
96 
97 	/* Resources for implementing the notification channel from the device
98 	 * to the driver. fwqp is the firmware end of an RC connection; the
99 	 * other end is vqqp used by the driver. cq is where completions are
100 	 * reported.
101 	 */
102 	struct mlx5_vdpa_cq cq;
103 	struct mlx5_vdpa_qp fwqp;
104 	struct mlx5_vdpa_qp vqqp;
105 
106 	/* umem resources are required for the virtqueue operation. They're use
107 	 * is internal and they must be provided by the driver.
108 	 */
109 	struct mlx5_vdpa_umem umem1;
110 	struct mlx5_vdpa_umem umem2;
111 	struct mlx5_vdpa_umem umem3;
112 
113 	u32 counter_set_id;
114 	bool initialized;
115 	int index;
116 	u32 virtq_id;
117 	struct mlx5_vdpa_net *ndev;
118 	u16 avail_idx;
119 	u16 used_idx;
120 	int fw_state;
121 
122 	/* keep last in the struct */
123 	struct mlx5_vq_restore_info ri;
124 };
125 
126 static bool is_index_valid(struct mlx5_vdpa_dev *mvdev, u16 idx)
127 {
128 	if (!(mvdev->actual_features & BIT_ULL(VIRTIO_NET_F_MQ))) {
129 		if (!(mvdev->actual_features & BIT_ULL(VIRTIO_NET_F_CTRL_VQ)))
130 			return idx < 2;
131 		else
132 			return idx < 3;
133 	}
134 
135 	return idx <= mvdev->max_idx;
136 }
137 
138 static void free_resources(struct mlx5_vdpa_net *ndev);
139 static void init_mvqs(struct mlx5_vdpa_net *ndev);
140 static int setup_driver(struct mlx5_vdpa_dev *mvdev);
141 static void teardown_driver(struct mlx5_vdpa_net *ndev);
142 
143 static bool mlx5_vdpa_debug;
144 
145 #define MLX5_CVQ_MAX_ENT 16
146 
147 #define MLX5_LOG_VIO_FLAG(_feature)                                                                \
148 	do {                                                                                       \
149 		if (features & BIT_ULL(_feature))                                                  \
150 			mlx5_vdpa_info(mvdev, "%s\n", #_feature);                                  \
151 	} while (0)
152 
153 #define MLX5_LOG_VIO_STAT(_status)                                                                 \
154 	do {                                                                                       \
155 		if (status & (_status))                                                            \
156 			mlx5_vdpa_info(mvdev, "%s\n", #_status);                                   \
157 	} while (0)
158 
159 /* TODO: cross-endian support */
160 static inline bool mlx5_vdpa_is_little_endian(struct mlx5_vdpa_dev *mvdev)
161 {
162 	return virtio_legacy_is_little_endian() ||
163 		(mvdev->actual_features & BIT_ULL(VIRTIO_F_VERSION_1));
164 }
165 
166 static u16 mlx5vdpa16_to_cpu(struct mlx5_vdpa_dev *mvdev, __virtio16 val)
167 {
168 	return __virtio16_to_cpu(mlx5_vdpa_is_little_endian(mvdev), val);
169 }
170 
171 static __virtio16 cpu_to_mlx5vdpa16(struct mlx5_vdpa_dev *mvdev, u16 val)
172 {
173 	return __cpu_to_virtio16(mlx5_vdpa_is_little_endian(mvdev), val);
174 }
175 
176 static u16 ctrl_vq_idx(struct mlx5_vdpa_dev *mvdev)
177 {
178 	if (!(mvdev->actual_features & BIT_ULL(VIRTIO_NET_F_MQ)))
179 		return 2;
180 
181 	return mvdev->max_vqs;
182 }
183 
184 static bool is_ctrl_vq_idx(struct mlx5_vdpa_dev *mvdev, u16 idx)
185 {
186 	return idx == ctrl_vq_idx(mvdev);
187 }
188 
189 static void print_status(struct mlx5_vdpa_dev *mvdev, u8 status, bool set)
190 {
191 	if (status & ~VALID_STATUS_MASK)
192 		mlx5_vdpa_warn(mvdev, "Warning: there are invalid status bits 0x%x\n",
193 			       status & ~VALID_STATUS_MASK);
194 
195 	if (!mlx5_vdpa_debug)
196 		return;
197 
198 	mlx5_vdpa_info(mvdev, "driver status %s", set ? "set" : "get");
199 	if (set && !status) {
200 		mlx5_vdpa_info(mvdev, "driver resets the device\n");
201 		return;
202 	}
203 
204 	MLX5_LOG_VIO_STAT(VIRTIO_CONFIG_S_ACKNOWLEDGE);
205 	MLX5_LOG_VIO_STAT(VIRTIO_CONFIG_S_DRIVER);
206 	MLX5_LOG_VIO_STAT(VIRTIO_CONFIG_S_DRIVER_OK);
207 	MLX5_LOG_VIO_STAT(VIRTIO_CONFIG_S_FEATURES_OK);
208 	MLX5_LOG_VIO_STAT(VIRTIO_CONFIG_S_NEEDS_RESET);
209 	MLX5_LOG_VIO_STAT(VIRTIO_CONFIG_S_FAILED);
210 }
211 
212 static void print_features(struct mlx5_vdpa_dev *mvdev, u64 features, bool set)
213 {
214 	if (features & ~VALID_FEATURES_MASK)
215 		mlx5_vdpa_warn(mvdev, "There are invalid feature bits 0x%llx\n",
216 			       features & ~VALID_FEATURES_MASK);
217 
218 	if (!mlx5_vdpa_debug)
219 		return;
220 
221 	mlx5_vdpa_info(mvdev, "driver %s feature bits:\n", set ? "sets" : "reads");
222 	if (!features)
223 		mlx5_vdpa_info(mvdev, "all feature bits are cleared\n");
224 
225 	MLX5_LOG_VIO_FLAG(VIRTIO_NET_F_CSUM);
226 	MLX5_LOG_VIO_FLAG(VIRTIO_NET_F_GUEST_CSUM);
227 	MLX5_LOG_VIO_FLAG(VIRTIO_NET_F_CTRL_GUEST_OFFLOADS);
228 	MLX5_LOG_VIO_FLAG(VIRTIO_NET_F_MTU);
229 	MLX5_LOG_VIO_FLAG(VIRTIO_NET_F_MAC);
230 	MLX5_LOG_VIO_FLAG(VIRTIO_NET_F_GUEST_TSO4);
231 	MLX5_LOG_VIO_FLAG(VIRTIO_NET_F_GUEST_TSO6);
232 	MLX5_LOG_VIO_FLAG(VIRTIO_NET_F_GUEST_ECN);
233 	MLX5_LOG_VIO_FLAG(VIRTIO_NET_F_GUEST_UFO);
234 	MLX5_LOG_VIO_FLAG(VIRTIO_NET_F_HOST_TSO4);
235 	MLX5_LOG_VIO_FLAG(VIRTIO_NET_F_HOST_TSO6);
236 	MLX5_LOG_VIO_FLAG(VIRTIO_NET_F_HOST_ECN);
237 	MLX5_LOG_VIO_FLAG(VIRTIO_NET_F_HOST_UFO);
238 	MLX5_LOG_VIO_FLAG(VIRTIO_NET_F_MRG_RXBUF);
239 	MLX5_LOG_VIO_FLAG(VIRTIO_NET_F_STATUS);
240 	MLX5_LOG_VIO_FLAG(VIRTIO_NET_F_CTRL_VQ);
241 	MLX5_LOG_VIO_FLAG(VIRTIO_NET_F_CTRL_RX);
242 	MLX5_LOG_VIO_FLAG(VIRTIO_NET_F_CTRL_VLAN);
243 	MLX5_LOG_VIO_FLAG(VIRTIO_NET_F_CTRL_RX_EXTRA);
244 	MLX5_LOG_VIO_FLAG(VIRTIO_NET_F_GUEST_ANNOUNCE);
245 	MLX5_LOG_VIO_FLAG(VIRTIO_NET_F_MQ);
246 	MLX5_LOG_VIO_FLAG(VIRTIO_NET_F_CTRL_MAC_ADDR);
247 	MLX5_LOG_VIO_FLAG(VIRTIO_NET_F_HASH_REPORT);
248 	MLX5_LOG_VIO_FLAG(VIRTIO_NET_F_RSS);
249 	MLX5_LOG_VIO_FLAG(VIRTIO_NET_F_RSC_EXT);
250 	MLX5_LOG_VIO_FLAG(VIRTIO_NET_F_STANDBY);
251 	MLX5_LOG_VIO_FLAG(VIRTIO_NET_F_SPEED_DUPLEX);
252 	MLX5_LOG_VIO_FLAG(VIRTIO_F_NOTIFY_ON_EMPTY);
253 	MLX5_LOG_VIO_FLAG(VIRTIO_F_ANY_LAYOUT);
254 	MLX5_LOG_VIO_FLAG(VIRTIO_F_VERSION_1);
255 	MLX5_LOG_VIO_FLAG(VIRTIO_F_ACCESS_PLATFORM);
256 	MLX5_LOG_VIO_FLAG(VIRTIO_F_RING_PACKED);
257 	MLX5_LOG_VIO_FLAG(VIRTIO_F_ORDER_PLATFORM);
258 	MLX5_LOG_VIO_FLAG(VIRTIO_F_SR_IOV);
259 }
260 
261 static int create_tis(struct mlx5_vdpa_net *ndev)
262 {
263 	struct mlx5_vdpa_dev *mvdev = &ndev->mvdev;
264 	u32 in[MLX5_ST_SZ_DW(create_tis_in)] = {};
265 	void *tisc;
266 	int err;
267 
268 	tisc = MLX5_ADDR_OF(create_tis_in, in, ctx);
269 	MLX5_SET(tisc, tisc, transport_domain, ndev->res.tdn);
270 	err = mlx5_vdpa_create_tis(mvdev, in, &ndev->res.tisn);
271 	if (err)
272 		mlx5_vdpa_warn(mvdev, "create TIS (%d)\n", err);
273 
274 	return err;
275 }
276 
277 static void destroy_tis(struct mlx5_vdpa_net *ndev)
278 {
279 	mlx5_vdpa_destroy_tis(&ndev->mvdev, ndev->res.tisn);
280 }
281 
282 #define MLX5_VDPA_CQE_SIZE 64
283 #define MLX5_VDPA_LOG_CQE_SIZE ilog2(MLX5_VDPA_CQE_SIZE)
284 
285 static int cq_frag_buf_alloc(struct mlx5_vdpa_net *ndev, struct mlx5_vdpa_cq_buf *buf, int nent)
286 {
287 	struct mlx5_frag_buf *frag_buf = &buf->frag_buf;
288 	u8 log_wq_stride = MLX5_VDPA_LOG_CQE_SIZE;
289 	u8 log_wq_sz = MLX5_VDPA_LOG_CQE_SIZE;
290 	int err;
291 
292 	err = mlx5_frag_buf_alloc_node(ndev->mvdev.mdev, nent * MLX5_VDPA_CQE_SIZE, frag_buf,
293 				       ndev->mvdev.mdev->priv.numa_node);
294 	if (err)
295 		return err;
296 
297 	mlx5_init_fbc(frag_buf->frags, log_wq_stride, log_wq_sz, &buf->fbc);
298 
299 	buf->cqe_size = MLX5_VDPA_CQE_SIZE;
300 	buf->nent = nent;
301 
302 	return 0;
303 }
304 
305 static int umem_frag_buf_alloc(struct mlx5_vdpa_net *ndev, struct mlx5_vdpa_umem *umem, int size)
306 {
307 	struct mlx5_frag_buf *frag_buf = &umem->frag_buf;
308 
309 	return mlx5_frag_buf_alloc_node(ndev->mvdev.mdev, size, frag_buf,
310 					ndev->mvdev.mdev->priv.numa_node);
311 }
312 
313 static void cq_frag_buf_free(struct mlx5_vdpa_net *ndev, struct mlx5_vdpa_cq_buf *buf)
314 {
315 	mlx5_frag_buf_free(ndev->mvdev.mdev, &buf->frag_buf);
316 }
317 
318 static void *get_cqe(struct mlx5_vdpa_cq *vcq, int n)
319 {
320 	return mlx5_frag_buf_get_wqe(&vcq->buf.fbc, n);
321 }
322 
323 static void cq_frag_buf_init(struct mlx5_vdpa_cq *vcq, struct mlx5_vdpa_cq_buf *buf)
324 {
325 	struct mlx5_cqe64 *cqe64;
326 	void *cqe;
327 	int i;
328 
329 	for (i = 0; i < buf->nent; i++) {
330 		cqe = get_cqe(vcq, i);
331 		cqe64 = cqe;
332 		cqe64->op_own = MLX5_CQE_INVALID << 4;
333 	}
334 }
335 
336 static void *get_sw_cqe(struct mlx5_vdpa_cq *cq, int n)
337 {
338 	struct mlx5_cqe64 *cqe64 = get_cqe(cq, n & (cq->cqe - 1));
339 
340 	if (likely(get_cqe_opcode(cqe64) != MLX5_CQE_INVALID) &&
341 	    !((cqe64->op_own & MLX5_CQE_OWNER_MASK) ^ !!(n & cq->cqe)))
342 		return cqe64;
343 
344 	return NULL;
345 }
346 
347 static void rx_post(struct mlx5_vdpa_qp *vqp, int n)
348 {
349 	vqp->head += n;
350 	vqp->db.db[0] = cpu_to_be32(vqp->head);
351 }
352 
353 static void qp_prepare(struct mlx5_vdpa_net *ndev, bool fw, void *in,
354 		       struct mlx5_vdpa_virtqueue *mvq, u32 num_ent)
355 {
356 	struct mlx5_vdpa_qp *vqp;
357 	__be64 *pas;
358 	void *qpc;
359 
360 	vqp = fw ? &mvq->fwqp : &mvq->vqqp;
361 	MLX5_SET(create_qp_in, in, uid, ndev->mvdev.res.uid);
362 	qpc = MLX5_ADDR_OF(create_qp_in, in, qpc);
363 	if (vqp->fw) {
364 		/* Firmware QP is allocated by the driver for the firmware's
365 		 * use so we can skip part of the params as they will be chosen by firmware
366 		 */
367 		qpc = MLX5_ADDR_OF(create_qp_in, in, qpc);
368 		MLX5_SET(qpc, qpc, rq_type, MLX5_ZERO_LEN_RQ);
369 		MLX5_SET(qpc, qpc, no_sq, 1);
370 		return;
371 	}
372 
373 	MLX5_SET(qpc, qpc, st, MLX5_QP_ST_RC);
374 	MLX5_SET(qpc, qpc, pm_state, MLX5_QP_PM_MIGRATED);
375 	MLX5_SET(qpc, qpc, pd, ndev->mvdev.res.pdn);
376 	MLX5_SET(qpc, qpc, mtu, MLX5_QPC_MTU_256_BYTES);
377 	MLX5_SET(qpc, qpc, uar_page, ndev->mvdev.res.uar->index);
378 	MLX5_SET(qpc, qpc, log_page_size, vqp->frag_buf.page_shift - MLX5_ADAPTER_PAGE_SHIFT);
379 	MLX5_SET(qpc, qpc, no_sq, 1);
380 	MLX5_SET(qpc, qpc, cqn_rcv, mvq->cq.mcq.cqn);
381 	MLX5_SET(qpc, qpc, log_rq_size, ilog2(num_ent));
382 	MLX5_SET(qpc, qpc, rq_type, MLX5_NON_ZERO_RQ);
383 	pas = (__be64 *)MLX5_ADDR_OF(create_qp_in, in, pas);
384 	mlx5_fill_page_frag_array(&vqp->frag_buf, pas);
385 }
386 
387 static int rq_buf_alloc(struct mlx5_vdpa_net *ndev, struct mlx5_vdpa_qp *vqp, u32 num_ent)
388 {
389 	return mlx5_frag_buf_alloc_node(ndev->mvdev.mdev,
390 					num_ent * sizeof(struct mlx5_wqe_data_seg), &vqp->frag_buf,
391 					ndev->mvdev.mdev->priv.numa_node);
392 }
393 
394 static void rq_buf_free(struct mlx5_vdpa_net *ndev, struct mlx5_vdpa_qp *vqp)
395 {
396 	mlx5_frag_buf_free(ndev->mvdev.mdev, &vqp->frag_buf);
397 }
398 
399 static int qp_create(struct mlx5_vdpa_net *ndev, struct mlx5_vdpa_virtqueue *mvq,
400 		     struct mlx5_vdpa_qp *vqp)
401 {
402 	struct mlx5_core_dev *mdev = ndev->mvdev.mdev;
403 	int inlen = MLX5_ST_SZ_BYTES(create_qp_in);
404 	u32 out[MLX5_ST_SZ_DW(create_qp_out)] = {};
405 	void *qpc;
406 	void *in;
407 	int err;
408 
409 	if (!vqp->fw) {
410 		vqp = &mvq->vqqp;
411 		err = rq_buf_alloc(ndev, vqp, mvq->num_ent);
412 		if (err)
413 			return err;
414 
415 		err = mlx5_db_alloc(ndev->mvdev.mdev, &vqp->db);
416 		if (err)
417 			goto err_db;
418 		inlen += vqp->frag_buf.npages * sizeof(__be64);
419 	}
420 
421 	in = kzalloc(inlen, GFP_KERNEL);
422 	if (!in) {
423 		err = -ENOMEM;
424 		goto err_kzalloc;
425 	}
426 
427 	qp_prepare(ndev, vqp->fw, in, mvq, mvq->num_ent);
428 	qpc = MLX5_ADDR_OF(create_qp_in, in, qpc);
429 	MLX5_SET(qpc, qpc, st, MLX5_QP_ST_RC);
430 	MLX5_SET(qpc, qpc, pm_state, MLX5_QP_PM_MIGRATED);
431 	MLX5_SET(qpc, qpc, pd, ndev->mvdev.res.pdn);
432 	MLX5_SET(qpc, qpc, mtu, MLX5_QPC_MTU_256_BYTES);
433 	if (!vqp->fw)
434 		MLX5_SET64(qpc, qpc, dbr_addr, vqp->db.dma);
435 	MLX5_SET(create_qp_in, in, opcode, MLX5_CMD_OP_CREATE_QP);
436 	err = mlx5_cmd_exec(mdev, in, inlen, out, sizeof(out));
437 	kfree(in);
438 	if (err)
439 		goto err_kzalloc;
440 
441 	vqp->mqp.uid = ndev->mvdev.res.uid;
442 	vqp->mqp.qpn = MLX5_GET(create_qp_out, out, qpn);
443 
444 	if (!vqp->fw)
445 		rx_post(vqp, mvq->num_ent);
446 
447 	return 0;
448 
449 err_kzalloc:
450 	if (!vqp->fw)
451 		mlx5_db_free(ndev->mvdev.mdev, &vqp->db);
452 err_db:
453 	if (!vqp->fw)
454 		rq_buf_free(ndev, vqp);
455 
456 	return err;
457 }
458 
459 static void qp_destroy(struct mlx5_vdpa_net *ndev, struct mlx5_vdpa_qp *vqp)
460 {
461 	u32 in[MLX5_ST_SZ_DW(destroy_qp_in)] = {};
462 
463 	MLX5_SET(destroy_qp_in, in, opcode, MLX5_CMD_OP_DESTROY_QP);
464 	MLX5_SET(destroy_qp_in, in, qpn, vqp->mqp.qpn);
465 	MLX5_SET(destroy_qp_in, in, uid, ndev->mvdev.res.uid);
466 	if (mlx5_cmd_exec_in(ndev->mvdev.mdev, destroy_qp, in))
467 		mlx5_vdpa_warn(&ndev->mvdev, "destroy qp 0x%x\n", vqp->mqp.qpn);
468 	if (!vqp->fw) {
469 		mlx5_db_free(ndev->mvdev.mdev, &vqp->db);
470 		rq_buf_free(ndev, vqp);
471 	}
472 }
473 
474 static void *next_cqe_sw(struct mlx5_vdpa_cq *cq)
475 {
476 	return get_sw_cqe(cq, cq->mcq.cons_index);
477 }
478 
479 static int mlx5_vdpa_poll_one(struct mlx5_vdpa_cq *vcq)
480 {
481 	struct mlx5_cqe64 *cqe64;
482 
483 	cqe64 = next_cqe_sw(vcq);
484 	if (!cqe64)
485 		return -EAGAIN;
486 
487 	vcq->mcq.cons_index++;
488 	return 0;
489 }
490 
491 static void mlx5_vdpa_handle_completions(struct mlx5_vdpa_virtqueue *mvq, int num)
492 {
493 	struct mlx5_vdpa_net *ndev = mvq->ndev;
494 	struct vdpa_callback *event_cb;
495 
496 	event_cb = &ndev->event_cbs[mvq->index];
497 	mlx5_cq_set_ci(&mvq->cq.mcq);
498 
499 	/* make sure CQ cosumer update is visible to the hardware before updating
500 	 * RX doorbell record.
501 	 */
502 	dma_wmb();
503 	rx_post(&mvq->vqqp, num);
504 	if (event_cb->callback)
505 		event_cb->callback(event_cb->private);
506 }
507 
508 static void mlx5_vdpa_cq_comp(struct mlx5_core_cq *mcq, struct mlx5_eqe *eqe)
509 {
510 	struct mlx5_vdpa_virtqueue *mvq = container_of(mcq, struct mlx5_vdpa_virtqueue, cq.mcq);
511 	struct mlx5_vdpa_net *ndev = mvq->ndev;
512 	void __iomem *uar_page = ndev->mvdev.res.uar->map;
513 	int num = 0;
514 
515 	while (!mlx5_vdpa_poll_one(&mvq->cq)) {
516 		num++;
517 		if (num > mvq->num_ent / 2) {
518 			/* If completions keep coming while we poll, we want to
519 			 * let the hardware know that we consumed them by
520 			 * updating the doorbell record.  We also let vdpa core
521 			 * know about this so it passes it on the virtio driver
522 			 * on the guest.
523 			 */
524 			mlx5_vdpa_handle_completions(mvq, num);
525 			num = 0;
526 		}
527 	}
528 
529 	if (num)
530 		mlx5_vdpa_handle_completions(mvq, num);
531 
532 	mlx5_cq_arm(&mvq->cq.mcq, MLX5_CQ_DB_REQ_NOT, uar_page, mvq->cq.mcq.cons_index);
533 }
534 
535 static int cq_create(struct mlx5_vdpa_net *ndev, u16 idx, u32 num_ent)
536 {
537 	struct mlx5_vdpa_virtqueue *mvq = &ndev->vqs[idx];
538 	struct mlx5_core_dev *mdev = ndev->mvdev.mdev;
539 	void __iomem *uar_page = ndev->mvdev.res.uar->map;
540 	u32 out[MLX5_ST_SZ_DW(create_cq_out)];
541 	struct mlx5_vdpa_cq *vcq = &mvq->cq;
542 	__be64 *pas;
543 	int inlen;
544 	void *cqc;
545 	void *in;
546 	int err;
547 	int eqn;
548 
549 	err = mlx5_db_alloc(mdev, &vcq->db);
550 	if (err)
551 		return err;
552 
553 	vcq->mcq.set_ci_db = vcq->db.db;
554 	vcq->mcq.arm_db = vcq->db.db + 1;
555 	vcq->mcq.cqe_sz = 64;
556 
557 	err = cq_frag_buf_alloc(ndev, &vcq->buf, num_ent);
558 	if (err)
559 		goto err_db;
560 
561 	cq_frag_buf_init(vcq, &vcq->buf);
562 
563 	inlen = MLX5_ST_SZ_BYTES(create_cq_in) +
564 		MLX5_FLD_SZ_BYTES(create_cq_in, pas[0]) * vcq->buf.frag_buf.npages;
565 	in = kzalloc(inlen, GFP_KERNEL);
566 	if (!in) {
567 		err = -ENOMEM;
568 		goto err_vzalloc;
569 	}
570 
571 	MLX5_SET(create_cq_in, in, uid, ndev->mvdev.res.uid);
572 	pas = (__be64 *)MLX5_ADDR_OF(create_cq_in, in, pas);
573 	mlx5_fill_page_frag_array(&vcq->buf.frag_buf, pas);
574 
575 	cqc = MLX5_ADDR_OF(create_cq_in, in, cq_context);
576 	MLX5_SET(cqc, cqc, log_page_size, vcq->buf.frag_buf.page_shift - MLX5_ADAPTER_PAGE_SHIFT);
577 
578 	/* Use vector 0 by default. Consider adding code to choose least used
579 	 * vector.
580 	 */
581 	err = mlx5_vector2eqn(mdev, 0, &eqn);
582 	if (err)
583 		goto err_vec;
584 
585 	cqc = MLX5_ADDR_OF(create_cq_in, in, cq_context);
586 	MLX5_SET(cqc, cqc, log_cq_size, ilog2(num_ent));
587 	MLX5_SET(cqc, cqc, uar_page, ndev->mvdev.res.uar->index);
588 	MLX5_SET(cqc, cqc, c_eqn_or_apu_element, eqn);
589 	MLX5_SET64(cqc, cqc, dbr_addr, vcq->db.dma);
590 
591 	err = mlx5_core_create_cq(mdev, &vcq->mcq, in, inlen, out, sizeof(out));
592 	if (err)
593 		goto err_vec;
594 
595 	vcq->mcq.comp = mlx5_vdpa_cq_comp;
596 	vcq->cqe = num_ent;
597 	vcq->mcq.set_ci_db = vcq->db.db;
598 	vcq->mcq.arm_db = vcq->db.db + 1;
599 	mlx5_cq_arm(&mvq->cq.mcq, MLX5_CQ_DB_REQ_NOT, uar_page, mvq->cq.mcq.cons_index);
600 	kfree(in);
601 	return 0;
602 
603 err_vec:
604 	kfree(in);
605 err_vzalloc:
606 	cq_frag_buf_free(ndev, &vcq->buf);
607 err_db:
608 	mlx5_db_free(ndev->mvdev.mdev, &vcq->db);
609 	return err;
610 }
611 
612 static void cq_destroy(struct mlx5_vdpa_net *ndev, u16 idx)
613 {
614 	struct mlx5_vdpa_virtqueue *mvq = &ndev->vqs[idx];
615 	struct mlx5_core_dev *mdev = ndev->mvdev.mdev;
616 	struct mlx5_vdpa_cq *vcq = &mvq->cq;
617 
618 	if (mlx5_core_destroy_cq(mdev, &vcq->mcq)) {
619 		mlx5_vdpa_warn(&ndev->mvdev, "destroy CQ 0x%x\n", vcq->mcq.cqn);
620 		return;
621 	}
622 	cq_frag_buf_free(ndev, &vcq->buf);
623 	mlx5_db_free(ndev->mvdev.mdev, &vcq->db);
624 }
625 
626 static void set_umem_size(struct mlx5_vdpa_net *ndev, struct mlx5_vdpa_virtqueue *mvq, int num,
627 			  struct mlx5_vdpa_umem **umemp)
628 {
629 	struct mlx5_core_dev *mdev = ndev->mvdev.mdev;
630 	int p_a;
631 	int p_b;
632 
633 	switch (num) {
634 	case 1:
635 		p_a = MLX5_CAP_DEV_VDPA_EMULATION(mdev, umem_1_buffer_param_a);
636 		p_b = MLX5_CAP_DEV_VDPA_EMULATION(mdev, umem_1_buffer_param_b);
637 		*umemp = &mvq->umem1;
638 		break;
639 	case 2:
640 		p_a = MLX5_CAP_DEV_VDPA_EMULATION(mdev, umem_2_buffer_param_a);
641 		p_b = MLX5_CAP_DEV_VDPA_EMULATION(mdev, umem_2_buffer_param_b);
642 		*umemp = &mvq->umem2;
643 		break;
644 	case 3:
645 		p_a = MLX5_CAP_DEV_VDPA_EMULATION(mdev, umem_3_buffer_param_a);
646 		p_b = MLX5_CAP_DEV_VDPA_EMULATION(mdev, umem_3_buffer_param_b);
647 		*umemp = &mvq->umem3;
648 		break;
649 	}
650 	(*umemp)->size = p_a * mvq->num_ent + p_b;
651 }
652 
653 static void umem_frag_buf_free(struct mlx5_vdpa_net *ndev, struct mlx5_vdpa_umem *umem)
654 {
655 	mlx5_frag_buf_free(ndev->mvdev.mdev, &umem->frag_buf);
656 }
657 
658 static int create_umem(struct mlx5_vdpa_net *ndev, struct mlx5_vdpa_virtqueue *mvq, int num)
659 {
660 	int inlen;
661 	u32 out[MLX5_ST_SZ_DW(create_umem_out)] = {};
662 	void *um;
663 	void *in;
664 	int err;
665 	__be64 *pas;
666 	struct mlx5_vdpa_umem *umem;
667 
668 	set_umem_size(ndev, mvq, num, &umem);
669 	err = umem_frag_buf_alloc(ndev, umem, umem->size);
670 	if (err)
671 		return err;
672 
673 	inlen = MLX5_ST_SZ_BYTES(create_umem_in) + MLX5_ST_SZ_BYTES(mtt) * umem->frag_buf.npages;
674 
675 	in = kzalloc(inlen, GFP_KERNEL);
676 	if (!in) {
677 		err = -ENOMEM;
678 		goto err_in;
679 	}
680 
681 	MLX5_SET(create_umem_in, in, opcode, MLX5_CMD_OP_CREATE_UMEM);
682 	MLX5_SET(create_umem_in, in, uid, ndev->mvdev.res.uid);
683 	um = MLX5_ADDR_OF(create_umem_in, in, umem);
684 	MLX5_SET(umem, um, log_page_size, umem->frag_buf.page_shift - MLX5_ADAPTER_PAGE_SHIFT);
685 	MLX5_SET64(umem, um, num_of_mtt, umem->frag_buf.npages);
686 
687 	pas = (__be64 *)MLX5_ADDR_OF(umem, um, mtt[0]);
688 	mlx5_fill_page_frag_array_perm(&umem->frag_buf, pas, MLX5_MTT_PERM_RW);
689 
690 	err = mlx5_cmd_exec(ndev->mvdev.mdev, in, inlen, out, sizeof(out));
691 	if (err) {
692 		mlx5_vdpa_warn(&ndev->mvdev, "create umem(%d)\n", err);
693 		goto err_cmd;
694 	}
695 
696 	kfree(in);
697 	umem->id = MLX5_GET(create_umem_out, out, umem_id);
698 
699 	return 0;
700 
701 err_cmd:
702 	kfree(in);
703 err_in:
704 	umem_frag_buf_free(ndev, umem);
705 	return err;
706 }
707 
708 static void umem_destroy(struct mlx5_vdpa_net *ndev, struct mlx5_vdpa_virtqueue *mvq, int num)
709 {
710 	u32 in[MLX5_ST_SZ_DW(destroy_umem_in)] = {};
711 	u32 out[MLX5_ST_SZ_DW(destroy_umem_out)] = {};
712 	struct mlx5_vdpa_umem *umem;
713 
714 	switch (num) {
715 	case 1:
716 		umem = &mvq->umem1;
717 		break;
718 	case 2:
719 		umem = &mvq->umem2;
720 		break;
721 	case 3:
722 		umem = &mvq->umem3;
723 		break;
724 	}
725 
726 	MLX5_SET(destroy_umem_in, in, opcode, MLX5_CMD_OP_DESTROY_UMEM);
727 	MLX5_SET(destroy_umem_in, in, umem_id, umem->id);
728 	if (mlx5_cmd_exec(ndev->mvdev.mdev, in, sizeof(in), out, sizeof(out)))
729 		return;
730 
731 	umem_frag_buf_free(ndev, umem);
732 }
733 
734 static int umems_create(struct mlx5_vdpa_net *ndev, struct mlx5_vdpa_virtqueue *mvq)
735 {
736 	int num;
737 	int err;
738 
739 	for (num = 1; num <= 3; num++) {
740 		err = create_umem(ndev, mvq, num);
741 		if (err)
742 			goto err_umem;
743 	}
744 	return 0;
745 
746 err_umem:
747 	for (num--; num > 0; num--)
748 		umem_destroy(ndev, mvq, num);
749 
750 	return err;
751 }
752 
753 static void umems_destroy(struct mlx5_vdpa_net *ndev, struct mlx5_vdpa_virtqueue *mvq)
754 {
755 	int num;
756 
757 	for (num = 3; num > 0; num--)
758 		umem_destroy(ndev, mvq, num);
759 }
760 
761 static int get_queue_type(struct mlx5_vdpa_net *ndev)
762 {
763 	u32 type_mask;
764 
765 	type_mask = MLX5_CAP_DEV_VDPA_EMULATION(ndev->mvdev.mdev, virtio_queue_type);
766 
767 	/* prefer split queue */
768 	if (type_mask & MLX5_VIRTIO_EMULATION_CAP_VIRTIO_QUEUE_TYPE_SPLIT)
769 		return MLX5_VIRTIO_EMULATION_VIRTIO_QUEUE_TYPE_SPLIT;
770 
771 	WARN_ON(!(type_mask & MLX5_VIRTIO_EMULATION_CAP_VIRTIO_QUEUE_TYPE_PACKED));
772 
773 	return MLX5_VIRTIO_EMULATION_VIRTIO_QUEUE_TYPE_PACKED;
774 }
775 
776 static bool vq_is_tx(u16 idx)
777 {
778 	return idx % 2;
779 }
780 
781 enum {
782 	MLX5_VIRTIO_NET_F_MRG_RXBUF = 2,
783 	MLX5_VIRTIO_NET_F_HOST_ECN = 4,
784 	MLX5_VIRTIO_NET_F_GUEST_ECN = 6,
785 	MLX5_VIRTIO_NET_F_GUEST_TSO6 = 7,
786 	MLX5_VIRTIO_NET_F_GUEST_TSO4 = 8,
787 	MLX5_VIRTIO_NET_F_GUEST_CSUM = 9,
788 	MLX5_VIRTIO_NET_F_CSUM = 10,
789 	MLX5_VIRTIO_NET_F_HOST_TSO6 = 11,
790 	MLX5_VIRTIO_NET_F_HOST_TSO4 = 12,
791 };
792 
793 static u16 get_features(u64 features)
794 {
795 	return (!!(features & BIT_ULL(VIRTIO_NET_F_MRG_RXBUF)) << MLX5_VIRTIO_NET_F_MRG_RXBUF) |
796 	       (!!(features & BIT_ULL(VIRTIO_NET_F_HOST_ECN)) << MLX5_VIRTIO_NET_F_HOST_ECN) |
797 	       (!!(features & BIT_ULL(VIRTIO_NET_F_GUEST_ECN)) << MLX5_VIRTIO_NET_F_GUEST_ECN) |
798 	       (!!(features & BIT_ULL(VIRTIO_NET_F_GUEST_TSO6)) << MLX5_VIRTIO_NET_F_GUEST_TSO6) |
799 	       (!!(features & BIT_ULL(VIRTIO_NET_F_GUEST_TSO4)) << MLX5_VIRTIO_NET_F_GUEST_TSO4) |
800 	       (!!(features & BIT_ULL(VIRTIO_NET_F_CSUM)) << MLX5_VIRTIO_NET_F_CSUM) |
801 	       (!!(features & BIT_ULL(VIRTIO_NET_F_HOST_TSO6)) << MLX5_VIRTIO_NET_F_HOST_TSO6) |
802 	       (!!(features & BIT_ULL(VIRTIO_NET_F_HOST_TSO4)) << MLX5_VIRTIO_NET_F_HOST_TSO4);
803 }
804 
805 static bool counters_supported(const struct mlx5_vdpa_dev *mvdev)
806 {
807 	return MLX5_CAP_GEN_64(mvdev->mdev, general_obj_types) &
808 	       BIT_ULL(MLX5_OBJ_TYPE_VIRTIO_Q_COUNTERS);
809 }
810 
811 static int create_virtqueue(struct mlx5_vdpa_net *ndev, struct mlx5_vdpa_virtqueue *mvq)
812 {
813 	int inlen = MLX5_ST_SZ_BYTES(create_virtio_net_q_in);
814 	u32 out[MLX5_ST_SZ_DW(create_virtio_net_q_out)] = {};
815 	void *obj_context;
816 	u16 mlx_features;
817 	void *cmd_hdr;
818 	void *vq_ctx;
819 	void *in;
820 	int err;
821 
822 	err = umems_create(ndev, mvq);
823 	if (err)
824 		return err;
825 
826 	in = kzalloc(inlen, GFP_KERNEL);
827 	if (!in) {
828 		err = -ENOMEM;
829 		goto err_alloc;
830 	}
831 
832 	mlx_features = get_features(ndev->mvdev.actual_features);
833 	cmd_hdr = MLX5_ADDR_OF(create_virtio_net_q_in, in, general_obj_in_cmd_hdr);
834 
835 	MLX5_SET(general_obj_in_cmd_hdr, cmd_hdr, opcode, MLX5_CMD_OP_CREATE_GENERAL_OBJECT);
836 	MLX5_SET(general_obj_in_cmd_hdr, cmd_hdr, obj_type, MLX5_OBJ_TYPE_VIRTIO_NET_Q);
837 	MLX5_SET(general_obj_in_cmd_hdr, cmd_hdr, uid, ndev->mvdev.res.uid);
838 
839 	obj_context = MLX5_ADDR_OF(create_virtio_net_q_in, in, obj_context);
840 	MLX5_SET(virtio_net_q_object, obj_context, hw_available_index, mvq->avail_idx);
841 	MLX5_SET(virtio_net_q_object, obj_context, hw_used_index, mvq->used_idx);
842 	MLX5_SET(virtio_net_q_object, obj_context, queue_feature_bit_mask_12_3,
843 		 mlx_features >> 3);
844 	MLX5_SET(virtio_net_q_object, obj_context, queue_feature_bit_mask_2_0,
845 		 mlx_features & 7);
846 	vq_ctx = MLX5_ADDR_OF(virtio_net_q_object, obj_context, virtio_q_context);
847 	MLX5_SET(virtio_q, vq_ctx, virtio_q_type, get_queue_type(ndev));
848 
849 	if (vq_is_tx(mvq->index))
850 		MLX5_SET(virtio_net_q_object, obj_context, tisn_or_qpn, ndev->res.tisn);
851 
852 	MLX5_SET(virtio_q, vq_ctx, event_mode, MLX5_VIRTIO_Q_EVENT_MODE_QP_MODE);
853 	MLX5_SET(virtio_q, vq_ctx, queue_index, mvq->index);
854 	MLX5_SET(virtio_q, vq_ctx, event_qpn_or_msix, mvq->fwqp.mqp.qpn);
855 	MLX5_SET(virtio_q, vq_ctx, queue_size, mvq->num_ent);
856 	MLX5_SET(virtio_q, vq_ctx, virtio_version_1_0,
857 		 !!(ndev->mvdev.actual_features & BIT_ULL(VIRTIO_F_VERSION_1)));
858 	MLX5_SET64(virtio_q, vq_ctx, desc_addr, mvq->desc_addr);
859 	MLX5_SET64(virtio_q, vq_ctx, used_addr, mvq->device_addr);
860 	MLX5_SET64(virtio_q, vq_ctx, available_addr, mvq->driver_addr);
861 	MLX5_SET(virtio_q, vq_ctx, virtio_q_mkey, ndev->mvdev.mr.mkey);
862 	MLX5_SET(virtio_q, vq_ctx, umem_1_id, mvq->umem1.id);
863 	MLX5_SET(virtio_q, vq_ctx, umem_1_size, mvq->umem1.size);
864 	MLX5_SET(virtio_q, vq_ctx, umem_2_id, mvq->umem2.id);
865 	MLX5_SET(virtio_q, vq_ctx, umem_2_size, mvq->umem2.size);
866 	MLX5_SET(virtio_q, vq_ctx, umem_3_id, mvq->umem3.id);
867 	MLX5_SET(virtio_q, vq_ctx, umem_3_size, mvq->umem3.size);
868 	MLX5_SET(virtio_q, vq_ctx, pd, ndev->mvdev.res.pdn);
869 	if (counters_supported(&ndev->mvdev))
870 		MLX5_SET(virtio_q, vq_ctx, counter_set_id, mvq->counter_set_id);
871 
872 	err = mlx5_cmd_exec(ndev->mvdev.mdev, in, inlen, out, sizeof(out));
873 	if (err)
874 		goto err_cmd;
875 
876 	mvq->fw_state = MLX5_VIRTIO_NET_Q_OBJECT_STATE_INIT;
877 	kfree(in);
878 	mvq->virtq_id = MLX5_GET(general_obj_out_cmd_hdr, out, obj_id);
879 
880 	return 0;
881 
882 err_cmd:
883 	kfree(in);
884 err_alloc:
885 	umems_destroy(ndev, mvq);
886 	return err;
887 }
888 
889 static void destroy_virtqueue(struct mlx5_vdpa_net *ndev, struct mlx5_vdpa_virtqueue *mvq)
890 {
891 	u32 in[MLX5_ST_SZ_DW(destroy_virtio_net_q_in)] = {};
892 	u32 out[MLX5_ST_SZ_DW(destroy_virtio_net_q_out)] = {};
893 
894 	MLX5_SET(destroy_virtio_net_q_in, in, general_obj_out_cmd_hdr.opcode,
895 		 MLX5_CMD_OP_DESTROY_GENERAL_OBJECT);
896 	MLX5_SET(destroy_virtio_net_q_in, in, general_obj_out_cmd_hdr.obj_id, mvq->virtq_id);
897 	MLX5_SET(destroy_virtio_net_q_in, in, general_obj_out_cmd_hdr.uid, ndev->mvdev.res.uid);
898 	MLX5_SET(destroy_virtio_net_q_in, in, general_obj_out_cmd_hdr.obj_type,
899 		 MLX5_OBJ_TYPE_VIRTIO_NET_Q);
900 	if (mlx5_cmd_exec(ndev->mvdev.mdev, in, sizeof(in), out, sizeof(out))) {
901 		mlx5_vdpa_warn(&ndev->mvdev, "destroy virtqueue 0x%x\n", mvq->virtq_id);
902 		return;
903 	}
904 	mvq->fw_state = MLX5_VIRTIO_NET_Q_OBJECT_NONE;
905 	umems_destroy(ndev, mvq);
906 }
907 
908 static u32 get_rqpn(struct mlx5_vdpa_virtqueue *mvq, bool fw)
909 {
910 	return fw ? mvq->vqqp.mqp.qpn : mvq->fwqp.mqp.qpn;
911 }
912 
913 static u32 get_qpn(struct mlx5_vdpa_virtqueue *mvq, bool fw)
914 {
915 	return fw ? mvq->fwqp.mqp.qpn : mvq->vqqp.mqp.qpn;
916 }
917 
918 static void alloc_inout(struct mlx5_vdpa_net *ndev, int cmd, void **in, int *inlen, void **out,
919 			int *outlen, u32 qpn, u32 rqpn)
920 {
921 	void *qpc;
922 	void *pp;
923 
924 	switch (cmd) {
925 	case MLX5_CMD_OP_2RST_QP:
926 		*inlen = MLX5_ST_SZ_BYTES(qp_2rst_in);
927 		*outlen = MLX5_ST_SZ_BYTES(qp_2rst_out);
928 		*in = kzalloc(*inlen, GFP_KERNEL);
929 		*out = kzalloc(*outlen, GFP_KERNEL);
930 		if (!*in || !*out)
931 			goto outerr;
932 
933 		MLX5_SET(qp_2rst_in, *in, opcode, cmd);
934 		MLX5_SET(qp_2rst_in, *in, uid, ndev->mvdev.res.uid);
935 		MLX5_SET(qp_2rst_in, *in, qpn, qpn);
936 		break;
937 	case MLX5_CMD_OP_RST2INIT_QP:
938 		*inlen = MLX5_ST_SZ_BYTES(rst2init_qp_in);
939 		*outlen = MLX5_ST_SZ_BYTES(rst2init_qp_out);
940 		*in = kzalloc(*inlen, GFP_KERNEL);
941 		*out = kzalloc(MLX5_ST_SZ_BYTES(rst2init_qp_out), GFP_KERNEL);
942 		if (!*in || !*out)
943 			goto outerr;
944 
945 		MLX5_SET(rst2init_qp_in, *in, opcode, cmd);
946 		MLX5_SET(rst2init_qp_in, *in, uid, ndev->mvdev.res.uid);
947 		MLX5_SET(rst2init_qp_in, *in, qpn, qpn);
948 		qpc = MLX5_ADDR_OF(rst2init_qp_in, *in, qpc);
949 		MLX5_SET(qpc, qpc, remote_qpn, rqpn);
950 		MLX5_SET(qpc, qpc, rwe, 1);
951 		pp = MLX5_ADDR_OF(qpc, qpc, primary_address_path);
952 		MLX5_SET(ads, pp, vhca_port_num, 1);
953 		break;
954 	case MLX5_CMD_OP_INIT2RTR_QP:
955 		*inlen = MLX5_ST_SZ_BYTES(init2rtr_qp_in);
956 		*outlen = MLX5_ST_SZ_BYTES(init2rtr_qp_out);
957 		*in = kzalloc(*inlen, GFP_KERNEL);
958 		*out = kzalloc(MLX5_ST_SZ_BYTES(init2rtr_qp_out), GFP_KERNEL);
959 		if (!*in || !*out)
960 			goto outerr;
961 
962 		MLX5_SET(init2rtr_qp_in, *in, opcode, cmd);
963 		MLX5_SET(init2rtr_qp_in, *in, uid, ndev->mvdev.res.uid);
964 		MLX5_SET(init2rtr_qp_in, *in, qpn, qpn);
965 		qpc = MLX5_ADDR_OF(rst2init_qp_in, *in, qpc);
966 		MLX5_SET(qpc, qpc, mtu, MLX5_QPC_MTU_256_BYTES);
967 		MLX5_SET(qpc, qpc, log_msg_max, 30);
968 		MLX5_SET(qpc, qpc, remote_qpn, rqpn);
969 		pp = MLX5_ADDR_OF(qpc, qpc, primary_address_path);
970 		MLX5_SET(ads, pp, fl, 1);
971 		break;
972 	case MLX5_CMD_OP_RTR2RTS_QP:
973 		*inlen = MLX5_ST_SZ_BYTES(rtr2rts_qp_in);
974 		*outlen = MLX5_ST_SZ_BYTES(rtr2rts_qp_out);
975 		*in = kzalloc(*inlen, GFP_KERNEL);
976 		*out = kzalloc(MLX5_ST_SZ_BYTES(rtr2rts_qp_out), GFP_KERNEL);
977 		if (!*in || !*out)
978 			goto outerr;
979 
980 		MLX5_SET(rtr2rts_qp_in, *in, opcode, cmd);
981 		MLX5_SET(rtr2rts_qp_in, *in, uid, ndev->mvdev.res.uid);
982 		MLX5_SET(rtr2rts_qp_in, *in, qpn, qpn);
983 		qpc = MLX5_ADDR_OF(rst2init_qp_in, *in, qpc);
984 		pp = MLX5_ADDR_OF(qpc, qpc, primary_address_path);
985 		MLX5_SET(ads, pp, ack_timeout, 14);
986 		MLX5_SET(qpc, qpc, retry_count, 7);
987 		MLX5_SET(qpc, qpc, rnr_retry, 7);
988 		break;
989 	default:
990 		goto outerr_nullify;
991 	}
992 
993 	return;
994 
995 outerr:
996 	kfree(*in);
997 	kfree(*out);
998 outerr_nullify:
999 	*in = NULL;
1000 	*out = NULL;
1001 }
1002 
1003 static void free_inout(void *in, void *out)
1004 {
1005 	kfree(in);
1006 	kfree(out);
1007 }
1008 
1009 /* Two QPs are used by each virtqueue. One is used by the driver and one by
1010  * firmware. The fw argument indicates whether the subjected QP is the one used
1011  * by firmware.
1012  */
1013 static int modify_qp(struct mlx5_vdpa_net *ndev, struct mlx5_vdpa_virtqueue *mvq, bool fw, int cmd)
1014 {
1015 	int outlen;
1016 	int inlen;
1017 	void *out;
1018 	void *in;
1019 	int err;
1020 
1021 	alloc_inout(ndev, cmd, &in, &inlen, &out, &outlen, get_qpn(mvq, fw), get_rqpn(mvq, fw));
1022 	if (!in || !out)
1023 		return -ENOMEM;
1024 
1025 	err = mlx5_cmd_exec(ndev->mvdev.mdev, in, inlen, out, outlen);
1026 	free_inout(in, out);
1027 	return err;
1028 }
1029 
1030 static int connect_qps(struct mlx5_vdpa_net *ndev, struct mlx5_vdpa_virtqueue *mvq)
1031 {
1032 	int err;
1033 
1034 	err = modify_qp(ndev, mvq, true, MLX5_CMD_OP_2RST_QP);
1035 	if (err)
1036 		return err;
1037 
1038 	err = modify_qp(ndev, mvq, false, MLX5_CMD_OP_2RST_QP);
1039 	if (err)
1040 		return err;
1041 
1042 	err = modify_qp(ndev, mvq, true, MLX5_CMD_OP_RST2INIT_QP);
1043 	if (err)
1044 		return err;
1045 
1046 	err = modify_qp(ndev, mvq, false, MLX5_CMD_OP_RST2INIT_QP);
1047 	if (err)
1048 		return err;
1049 
1050 	err = modify_qp(ndev, mvq, true, MLX5_CMD_OP_INIT2RTR_QP);
1051 	if (err)
1052 		return err;
1053 
1054 	err = modify_qp(ndev, mvq, false, MLX5_CMD_OP_INIT2RTR_QP);
1055 	if (err)
1056 		return err;
1057 
1058 	return modify_qp(ndev, mvq, true, MLX5_CMD_OP_RTR2RTS_QP);
1059 }
1060 
1061 struct mlx5_virtq_attr {
1062 	u8 state;
1063 	u16 available_index;
1064 	u16 used_index;
1065 };
1066 
1067 static int query_virtqueue(struct mlx5_vdpa_net *ndev, struct mlx5_vdpa_virtqueue *mvq,
1068 			   struct mlx5_virtq_attr *attr)
1069 {
1070 	int outlen = MLX5_ST_SZ_BYTES(query_virtio_net_q_out);
1071 	u32 in[MLX5_ST_SZ_DW(query_virtio_net_q_in)] = {};
1072 	void *out;
1073 	void *obj_context;
1074 	void *cmd_hdr;
1075 	int err;
1076 
1077 	out = kzalloc(outlen, GFP_KERNEL);
1078 	if (!out)
1079 		return -ENOMEM;
1080 
1081 	cmd_hdr = MLX5_ADDR_OF(query_virtio_net_q_in, in, general_obj_in_cmd_hdr);
1082 
1083 	MLX5_SET(general_obj_in_cmd_hdr, cmd_hdr, opcode, MLX5_CMD_OP_QUERY_GENERAL_OBJECT);
1084 	MLX5_SET(general_obj_in_cmd_hdr, cmd_hdr, obj_type, MLX5_OBJ_TYPE_VIRTIO_NET_Q);
1085 	MLX5_SET(general_obj_in_cmd_hdr, cmd_hdr, obj_id, mvq->virtq_id);
1086 	MLX5_SET(general_obj_in_cmd_hdr, cmd_hdr, uid, ndev->mvdev.res.uid);
1087 	err = mlx5_cmd_exec(ndev->mvdev.mdev, in, sizeof(in), out, outlen);
1088 	if (err)
1089 		goto err_cmd;
1090 
1091 	obj_context = MLX5_ADDR_OF(query_virtio_net_q_out, out, obj_context);
1092 	memset(attr, 0, sizeof(*attr));
1093 	attr->state = MLX5_GET(virtio_net_q_object, obj_context, state);
1094 	attr->available_index = MLX5_GET(virtio_net_q_object, obj_context, hw_available_index);
1095 	attr->used_index = MLX5_GET(virtio_net_q_object, obj_context, hw_used_index);
1096 	kfree(out);
1097 	return 0;
1098 
1099 err_cmd:
1100 	kfree(out);
1101 	return err;
1102 }
1103 
1104 static bool is_valid_state_change(int oldstate, int newstate)
1105 {
1106 	switch (oldstate) {
1107 	case MLX5_VIRTIO_NET_Q_OBJECT_STATE_INIT:
1108 		return newstate == MLX5_VIRTIO_NET_Q_OBJECT_STATE_RDY;
1109 	case MLX5_VIRTIO_NET_Q_OBJECT_STATE_RDY:
1110 		return newstate == MLX5_VIRTIO_NET_Q_OBJECT_STATE_SUSPEND;
1111 	case MLX5_VIRTIO_NET_Q_OBJECT_STATE_SUSPEND:
1112 	case MLX5_VIRTIO_NET_Q_OBJECT_STATE_ERR:
1113 	default:
1114 		return false;
1115 	}
1116 }
1117 
1118 static int modify_virtqueue(struct mlx5_vdpa_net *ndev, struct mlx5_vdpa_virtqueue *mvq, int state)
1119 {
1120 	int inlen = MLX5_ST_SZ_BYTES(modify_virtio_net_q_in);
1121 	u32 out[MLX5_ST_SZ_DW(modify_virtio_net_q_out)] = {};
1122 	void *obj_context;
1123 	void *cmd_hdr;
1124 	void *in;
1125 	int err;
1126 
1127 	if (mvq->fw_state == MLX5_VIRTIO_NET_Q_OBJECT_NONE)
1128 		return 0;
1129 
1130 	if (!is_valid_state_change(mvq->fw_state, state))
1131 		return -EINVAL;
1132 
1133 	in = kzalloc(inlen, GFP_KERNEL);
1134 	if (!in)
1135 		return -ENOMEM;
1136 
1137 	cmd_hdr = MLX5_ADDR_OF(modify_virtio_net_q_in, in, general_obj_in_cmd_hdr);
1138 
1139 	MLX5_SET(general_obj_in_cmd_hdr, cmd_hdr, opcode, MLX5_CMD_OP_MODIFY_GENERAL_OBJECT);
1140 	MLX5_SET(general_obj_in_cmd_hdr, cmd_hdr, obj_type, MLX5_OBJ_TYPE_VIRTIO_NET_Q);
1141 	MLX5_SET(general_obj_in_cmd_hdr, cmd_hdr, obj_id, mvq->virtq_id);
1142 	MLX5_SET(general_obj_in_cmd_hdr, cmd_hdr, uid, ndev->mvdev.res.uid);
1143 
1144 	obj_context = MLX5_ADDR_OF(modify_virtio_net_q_in, in, obj_context);
1145 	MLX5_SET64(virtio_net_q_object, obj_context, modify_field_select,
1146 		   MLX5_VIRTQ_MODIFY_MASK_STATE);
1147 	MLX5_SET(virtio_net_q_object, obj_context, state, state);
1148 	err = mlx5_cmd_exec(ndev->mvdev.mdev, in, inlen, out, sizeof(out));
1149 	kfree(in);
1150 	if (!err)
1151 		mvq->fw_state = state;
1152 
1153 	return err;
1154 }
1155 
1156 static int counter_set_alloc(struct mlx5_vdpa_net *ndev, struct mlx5_vdpa_virtqueue *mvq)
1157 {
1158 	u32 in[MLX5_ST_SZ_DW(create_virtio_q_counters_in)] = {};
1159 	u32 out[MLX5_ST_SZ_DW(create_virtio_q_counters_out)] = {};
1160 	void *cmd_hdr;
1161 	int err;
1162 
1163 	if (!counters_supported(&ndev->mvdev))
1164 		return 0;
1165 
1166 	cmd_hdr = MLX5_ADDR_OF(create_virtio_q_counters_in, in, hdr);
1167 
1168 	MLX5_SET(general_obj_in_cmd_hdr, cmd_hdr, opcode, MLX5_CMD_OP_CREATE_GENERAL_OBJECT);
1169 	MLX5_SET(general_obj_in_cmd_hdr, cmd_hdr, obj_type, MLX5_OBJ_TYPE_VIRTIO_Q_COUNTERS);
1170 	MLX5_SET(general_obj_in_cmd_hdr, cmd_hdr, uid, ndev->mvdev.res.uid);
1171 
1172 	err = mlx5_cmd_exec(ndev->mvdev.mdev, in, sizeof(in), out, sizeof(out));
1173 	if (err)
1174 		return err;
1175 
1176 	mvq->counter_set_id = MLX5_GET(general_obj_out_cmd_hdr, out, obj_id);
1177 
1178 	return 0;
1179 }
1180 
1181 static void counter_set_dealloc(struct mlx5_vdpa_net *ndev, struct mlx5_vdpa_virtqueue *mvq)
1182 {
1183 	u32 in[MLX5_ST_SZ_DW(destroy_virtio_q_counters_in)] = {};
1184 	u32 out[MLX5_ST_SZ_DW(destroy_virtio_q_counters_out)] = {};
1185 
1186 	if (!counters_supported(&ndev->mvdev))
1187 		return;
1188 
1189 	MLX5_SET(destroy_virtio_q_counters_in, in, hdr.opcode, MLX5_CMD_OP_DESTROY_GENERAL_OBJECT);
1190 	MLX5_SET(destroy_virtio_q_counters_in, in, hdr.obj_id, mvq->counter_set_id);
1191 	MLX5_SET(destroy_virtio_q_counters_in, in, hdr.uid, ndev->mvdev.res.uid);
1192 	MLX5_SET(destroy_virtio_q_counters_in, in, hdr.obj_type, MLX5_OBJ_TYPE_VIRTIO_Q_COUNTERS);
1193 	if (mlx5_cmd_exec(ndev->mvdev.mdev, in, sizeof(in), out, sizeof(out)))
1194 		mlx5_vdpa_warn(&ndev->mvdev, "dealloc counter set 0x%x\n", mvq->counter_set_id);
1195 }
1196 
1197 static int setup_vq(struct mlx5_vdpa_net *ndev, struct mlx5_vdpa_virtqueue *mvq)
1198 {
1199 	u16 idx = mvq->index;
1200 	int err;
1201 
1202 	if (!mvq->num_ent)
1203 		return 0;
1204 
1205 	if (mvq->initialized)
1206 		return 0;
1207 
1208 	err = cq_create(ndev, idx, mvq->num_ent);
1209 	if (err)
1210 		return err;
1211 
1212 	err = qp_create(ndev, mvq, &mvq->fwqp);
1213 	if (err)
1214 		goto err_fwqp;
1215 
1216 	err = qp_create(ndev, mvq, &mvq->vqqp);
1217 	if (err)
1218 		goto err_vqqp;
1219 
1220 	err = connect_qps(ndev, mvq);
1221 	if (err)
1222 		goto err_connect;
1223 
1224 	err = counter_set_alloc(ndev, mvq);
1225 	if (err)
1226 		goto err_counter;
1227 
1228 	err = create_virtqueue(ndev, mvq);
1229 	if (err)
1230 		goto err_connect;
1231 
1232 	if (mvq->ready) {
1233 		err = modify_virtqueue(ndev, mvq, MLX5_VIRTIO_NET_Q_OBJECT_STATE_RDY);
1234 		if (err) {
1235 			mlx5_vdpa_warn(&ndev->mvdev, "failed to modify to ready vq idx %d(%d)\n",
1236 				       idx, err);
1237 			goto err_connect;
1238 		}
1239 	}
1240 
1241 	mvq->initialized = true;
1242 	return 0;
1243 
1244 err_connect:
1245 	counter_set_dealloc(ndev, mvq);
1246 err_counter:
1247 	qp_destroy(ndev, &mvq->vqqp);
1248 err_vqqp:
1249 	qp_destroy(ndev, &mvq->fwqp);
1250 err_fwqp:
1251 	cq_destroy(ndev, idx);
1252 	return err;
1253 }
1254 
1255 static void suspend_vq(struct mlx5_vdpa_net *ndev, struct mlx5_vdpa_virtqueue *mvq)
1256 {
1257 	struct mlx5_virtq_attr attr;
1258 
1259 	if (!mvq->initialized)
1260 		return;
1261 
1262 	if (mvq->fw_state != MLX5_VIRTIO_NET_Q_OBJECT_STATE_RDY)
1263 		return;
1264 
1265 	if (modify_virtqueue(ndev, mvq, MLX5_VIRTIO_NET_Q_OBJECT_STATE_SUSPEND))
1266 		mlx5_vdpa_warn(&ndev->mvdev, "modify to suspend failed\n");
1267 
1268 	if (query_virtqueue(ndev, mvq, &attr)) {
1269 		mlx5_vdpa_warn(&ndev->mvdev, "failed to query virtqueue\n");
1270 		return;
1271 	}
1272 	mvq->avail_idx = attr.available_index;
1273 	mvq->used_idx = attr.used_index;
1274 }
1275 
1276 static void suspend_vqs(struct mlx5_vdpa_net *ndev)
1277 {
1278 	int i;
1279 
1280 	for (i = 0; i < ndev->mvdev.max_vqs; i++)
1281 		suspend_vq(ndev, &ndev->vqs[i]);
1282 }
1283 
1284 static void teardown_vq(struct mlx5_vdpa_net *ndev, struct mlx5_vdpa_virtqueue *mvq)
1285 {
1286 	if (!mvq->initialized)
1287 		return;
1288 
1289 	suspend_vq(ndev, mvq);
1290 	destroy_virtqueue(ndev, mvq);
1291 	counter_set_dealloc(ndev, mvq);
1292 	qp_destroy(ndev, &mvq->vqqp);
1293 	qp_destroy(ndev, &mvq->fwqp);
1294 	cq_destroy(ndev, mvq->index);
1295 	mvq->initialized = false;
1296 }
1297 
1298 static int create_rqt(struct mlx5_vdpa_net *ndev)
1299 {
1300 	int rqt_table_size = roundup_pow_of_two(ndev->rqt_size);
1301 	int act_sz = roundup_pow_of_two(ndev->cur_num_vqs / 2);
1302 	__be32 *list;
1303 	void *rqtc;
1304 	int inlen;
1305 	void *in;
1306 	int i, j;
1307 	int err;
1308 
1309 	inlen = MLX5_ST_SZ_BYTES(create_rqt_in) + rqt_table_size * MLX5_ST_SZ_BYTES(rq_num);
1310 	in = kzalloc(inlen, GFP_KERNEL);
1311 	if (!in)
1312 		return -ENOMEM;
1313 
1314 	MLX5_SET(create_rqt_in, in, uid, ndev->mvdev.res.uid);
1315 	rqtc = MLX5_ADDR_OF(create_rqt_in, in, rqt_context);
1316 
1317 	MLX5_SET(rqtc, rqtc, list_q_type, MLX5_RQTC_LIST_Q_TYPE_VIRTIO_NET_Q);
1318 	MLX5_SET(rqtc, rqtc, rqt_max_size, rqt_table_size);
1319 	list = MLX5_ADDR_OF(rqtc, rqtc, rq_num[0]);
1320 	for (i = 0, j = 0; i < act_sz; i++, j += 2)
1321 		list[i] = cpu_to_be32(ndev->vqs[j % ndev->cur_num_vqs].virtq_id);
1322 
1323 	MLX5_SET(rqtc, rqtc, rqt_actual_size, act_sz);
1324 	err = mlx5_vdpa_create_rqt(&ndev->mvdev, in, inlen, &ndev->res.rqtn);
1325 	kfree(in);
1326 	if (err)
1327 		return err;
1328 
1329 	return 0;
1330 }
1331 
1332 #define MLX5_MODIFY_RQT_NUM_RQS ((u64)1)
1333 
1334 static int modify_rqt(struct mlx5_vdpa_net *ndev, int num)
1335 {
1336 	int act_sz = roundup_pow_of_two(num / 2);
1337 	__be32 *list;
1338 	void *rqtc;
1339 	int inlen;
1340 	void *in;
1341 	int i, j;
1342 	int err;
1343 
1344 	inlen = MLX5_ST_SZ_BYTES(modify_rqt_in) + act_sz * MLX5_ST_SZ_BYTES(rq_num);
1345 	in = kzalloc(inlen, GFP_KERNEL);
1346 	if (!in)
1347 		return -ENOMEM;
1348 
1349 	MLX5_SET(modify_rqt_in, in, uid, ndev->mvdev.res.uid);
1350 	MLX5_SET64(modify_rqt_in, in, bitmask, MLX5_MODIFY_RQT_NUM_RQS);
1351 	rqtc = MLX5_ADDR_OF(modify_rqt_in, in, ctx);
1352 	MLX5_SET(rqtc, rqtc, list_q_type, MLX5_RQTC_LIST_Q_TYPE_VIRTIO_NET_Q);
1353 
1354 	list = MLX5_ADDR_OF(rqtc, rqtc, rq_num[0]);
1355 	for (i = 0, j = 0; i < act_sz; i++, j = j + 2)
1356 		list[i] = cpu_to_be32(ndev->vqs[j % num].virtq_id);
1357 
1358 	MLX5_SET(rqtc, rqtc, rqt_actual_size, act_sz);
1359 	err = mlx5_vdpa_modify_rqt(&ndev->mvdev, in, inlen, ndev->res.rqtn);
1360 	kfree(in);
1361 	if (err)
1362 		return err;
1363 
1364 	return 0;
1365 }
1366 
1367 static void destroy_rqt(struct mlx5_vdpa_net *ndev)
1368 {
1369 	mlx5_vdpa_destroy_rqt(&ndev->mvdev, ndev->res.rqtn);
1370 }
1371 
1372 static int create_tir(struct mlx5_vdpa_net *ndev)
1373 {
1374 #define HASH_IP_L4PORTS                                                                            \
1375 	(MLX5_HASH_FIELD_SEL_SRC_IP | MLX5_HASH_FIELD_SEL_DST_IP | MLX5_HASH_FIELD_SEL_L4_SPORT |  \
1376 	 MLX5_HASH_FIELD_SEL_L4_DPORT)
1377 	static const u8 rx_hash_toeplitz_key[] = { 0x2c, 0xc6, 0x81, 0xd1, 0x5b, 0xdb, 0xf4, 0xf7,
1378 						   0xfc, 0xa2, 0x83, 0x19, 0xdb, 0x1a, 0x3e, 0x94,
1379 						   0x6b, 0x9e, 0x38, 0xd9, 0x2c, 0x9c, 0x03, 0xd1,
1380 						   0xad, 0x99, 0x44, 0xa7, 0xd9, 0x56, 0x3d, 0x59,
1381 						   0x06, 0x3c, 0x25, 0xf3, 0xfc, 0x1f, 0xdc, 0x2a };
1382 	void *rss_key;
1383 	void *outer;
1384 	void *tirc;
1385 	void *in;
1386 	int err;
1387 
1388 	in = kzalloc(MLX5_ST_SZ_BYTES(create_tir_in), GFP_KERNEL);
1389 	if (!in)
1390 		return -ENOMEM;
1391 
1392 	MLX5_SET(create_tir_in, in, uid, ndev->mvdev.res.uid);
1393 	tirc = MLX5_ADDR_OF(create_tir_in, in, ctx);
1394 	MLX5_SET(tirc, tirc, disp_type, MLX5_TIRC_DISP_TYPE_INDIRECT);
1395 
1396 	MLX5_SET(tirc, tirc, rx_hash_symmetric, 1);
1397 	MLX5_SET(tirc, tirc, rx_hash_fn, MLX5_RX_HASH_FN_TOEPLITZ);
1398 	rss_key = MLX5_ADDR_OF(tirc, tirc, rx_hash_toeplitz_key);
1399 	memcpy(rss_key, rx_hash_toeplitz_key, sizeof(rx_hash_toeplitz_key));
1400 
1401 	outer = MLX5_ADDR_OF(tirc, tirc, rx_hash_field_selector_outer);
1402 	MLX5_SET(rx_hash_field_select, outer, l3_prot_type, MLX5_L3_PROT_TYPE_IPV4);
1403 	MLX5_SET(rx_hash_field_select, outer, l4_prot_type, MLX5_L4_PROT_TYPE_TCP);
1404 	MLX5_SET(rx_hash_field_select, outer, selected_fields, HASH_IP_L4PORTS);
1405 
1406 	MLX5_SET(tirc, tirc, indirect_table, ndev->res.rqtn);
1407 	MLX5_SET(tirc, tirc, transport_domain, ndev->res.tdn);
1408 
1409 	err = mlx5_vdpa_create_tir(&ndev->mvdev, in, &ndev->res.tirn);
1410 	kfree(in);
1411 	if (err)
1412 		return err;
1413 
1414 	mlx5_vdpa_add_tirn(ndev);
1415 	return err;
1416 }
1417 
1418 static void destroy_tir(struct mlx5_vdpa_net *ndev)
1419 {
1420 	mlx5_vdpa_remove_tirn(ndev);
1421 	mlx5_vdpa_destroy_tir(&ndev->mvdev, ndev->res.tirn);
1422 }
1423 
1424 #define MAX_STEERING_ENT 0x8000
1425 #define MAX_STEERING_GROUPS 2
1426 
1427 #if defined(CONFIG_MLX5_VDPA_STEERING_DEBUG)
1428        #define NUM_DESTS 2
1429 #else
1430        #define NUM_DESTS 1
1431 #endif
1432 
1433 static int add_steering_counters(struct mlx5_vdpa_net *ndev,
1434 				 struct macvlan_node *node,
1435 				 struct mlx5_flow_act *flow_act,
1436 				 struct mlx5_flow_destination *dests)
1437 {
1438 #if defined(CONFIG_MLX5_VDPA_STEERING_DEBUG)
1439 	int err;
1440 
1441 	node->ucast_counter.counter = mlx5_fc_create(ndev->mvdev.mdev, false);
1442 	if (IS_ERR(node->ucast_counter.counter))
1443 		return PTR_ERR(node->ucast_counter.counter);
1444 
1445 	node->mcast_counter.counter = mlx5_fc_create(ndev->mvdev.mdev, false);
1446 	if (IS_ERR(node->mcast_counter.counter)) {
1447 		err = PTR_ERR(node->mcast_counter.counter);
1448 		goto err_mcast_counter;
1449 	}
1450 
1451 	dests[1].type = MLX5_FLOW_DESTINATION_TYPE_COUNTER;
1452 	flow_act->action |= MLX5_FLOW_CONTEXT_ACTION_COUNT;
1453 	return 0;
1454 
1455 err_mcast_counter:
1456 	mlx5_fc_destroy(ndev->mvdev.mdev, node->ucast_counter.counter);
1457 	return err;
1458 #else
1459 	return 0;
1460 #endif
1461 }
1462 
1463 static void remove_steering_counters(struct mlx5_vdpa_net *ndev,
1464 				     struct macvlan_node *node)
1465 {
1466 #if defined(CONFIG_MLX5_VDPA_STEERING_DEBUG)
1467 	mlx5_fc_destroy(ndev->mvdev.mdev, node->mcast_counter.counter);
1468 	mlx5_fc_destroy(ndev->mvdev.mdev, node->ucast_counter.counter);
1469 #endif
1470 }
1471 
1472 static int mlx5_vdpa_add_mac_vlan_rules(struct mlx5_vdpa_net *ndev, u8 *mac,
1473 					struct macvlan_node *node)
1474 {
1475 	struct mlx5_flow_destination dests[NUM_DESTS] = {};
1476 	struct mlx5_flow_act flow_act = {};
1477 	struct mlx5_flow_spec *spec;
1478 	void *headers_c;
1479 	void *headers_v;
1480 	u8 *dmac_c;
1481 	u8 *dmac_v;
1482 	int err;
1483 	u16 vid;
1484 
1485 	spec = kvzalloc(sizeof(*spec), GFP_KERNEL);
1486 	if (!spec)
1487 		return -ENOMEM;
1488 
1489 	vid = key2vid(node->macvlan);
1490 	spec->match_criteria_enable = MLX5_MATCH_OUTER_HEADERS;
1491 	headers_c = MLX5_ADDR_OF(fte_match_param, spec->match_criteria, outer_headers);
1492 	headers_v = MLX5_ADDR_OF(fte_match_param, spec->match_value, outer_headers);
1493 	dmac_c = MLX5_ADDR_OF(fte_match_param, headers_c, outer_headers.dmac_47_16);
1494 	dmac_v = MLX5_ADDR_OF(fte_match_param, headers_v, outer_headers.dmac_47_16);
1495 	eth_broadcast_addr(dmac_c);
1496 	ether_addr_copy(dmac_v, mac);
1497 	if (ndev->mvdev.actual_features & BIT_ULL(VIRTIO_NET_F_CTRL_VLAN)) {
1498 		MLX5_SET(fte_match_set_lyr_2_4, headers_c, cvlan_tag, 1);
1499 		MLX5_SET_TO_ONES(fte_match_set_lyr_2_4, headers_c, first_vid);
1500 	}
1501 	if (node->tagged) {
1502 		MLX5_SET(fte_match_set_lyr_2_4, headers_v, cvlan_tag, 1);
1503 		MLX5_SET(fte_match_set_lyr_2_4, headers_v, first_vid, vid);
1504 	}
1505 	flow_act.action = MLX5_FLOW_CONTEXT_ACTION_FWD_DEST;
1506 	dests[0].type = MLX5_FLOW_DESTINATION_TYPE_TIR;
1507 	dests[0].tir_num = ndev->res.tirn;
1508 	err = add_steering_counters(ndev, node, &flow_act, dests);
1509 	if (err)
1510 		goto out_free;
1511 
1512 #if defined(CONFIG_MLX5_VDPA_STEERING_DEBUG)
1513 	dests[1].counter_id = mlx5_fc_id(node->ucast_counter.counter);
1514 #endif
1515 	node->ucast_rule = mlx5_add_flow_rules(ndev->rxft, spec, &flow_act, dests, NUM_DESTS);
1516 	if (IS_ERR(node->ucast_rule)) {
1517 		err = PTR_ERR(node->ucast_rule);
1518 		goto err_ucast;
1519 	}
1520 
1521 #if defined(CONFIG_MLX5_VDPA_STEERING_DEBUG)
1522 	dests[1].counter_id = mlx5_fc_id(node->mcast_counter.counter);
1523 #endif
1524 
1525 	memset(dmac_c, 0, ETH_ALEN);
1526 	memset(dmac_v, 0, ETH_ALEN);
1527 	dmac_c[0] = 1;
1528 	dmac_v[0] = 1;
1529 	node->mcast_rule = mlx5_add_flow_rules(ndev->rxft, spec, &flow_act, dests, NUM_DESTS);
1530 	if (IS_ERR(node->mcast_rule)) {
1531 		err = PTR_ERR(node->mcast_rule);
1532 		goto err_mcast;
1533 	}
1534 	kvfree(spec);
1535 	mlx5_vdpa_add_rx_counters(ndev, node);
1536 	return 0;
1537 
1538 err_mcast:
1539 	mlx5_del_flow_rules(node->ucast_rule);
1540 err_ucast:
1541 	remove_steering_counters(ndev, node);
1542 out_free:
1543 	kvfree(spec);
1544 	return err;
1545 }
1546 
1547 static void mlx5_vdpa_del_mac_vlan_rules(struct mlx5_vdpa_net *ndev,
1548 					 struct macvlan_node *node)
1549 {
1550 	mlx5_vdpa_remove_rx_counters(ndev, node);
1551 	mlx5_del_flow_rules(node->ucast_rule);
1552 	mlx5_del_flow_rules(node->mcast_rule);
1553 }
1554 
1555 static u64 search_val(u8 *mac, u16 vlan, bool tagged)
1556 {
1557 	u64 val;
1558 
1559 	if (!tagged)
1560 		vlan = MLX5V_UNTAGGED;
1561 
1562 	val = (u64)vlan << 48 |
1563 	      (u64)mac[0] << 40 |
1564 	      (u64)mac[1] << 32 |
1565 	      (u64)mac[2] << 24 |
1566 	      (u64)mac[3] << 16 |
1567 	      (u64)mac[4] << 8 |
1568 	      (u64)mac[5];
1569 
1570 	return val;
1571 }
1572 
1573 static struct macvlan_node *mac_vlan_lookup(struct mlx5_vdpa_net *ndev, u64 value)
1574 {
1575 	struct macvlan_node *pos;
1576 	u32 idx;
1577 
1578 	idx = hash_64(value, 8); // tbd 8
1579 	hlist_for_each_entry(pos, &ndev->macvlan_hash[idx], hlist) {
1580 		if (pos->macvlan == value)
1581 			return pos;
1582 	}
1583 	return NULL;
1584 }
1585 
1586 static int mac_vlan_add(struct mlx5_vdpa_net *ndev, u8 *mac, u16 vid, bool tagged)
1587 {
1588 	struct macvlan_node *ptr;
1589 	u64 val;
1590 	u32 idx;
1591 	int err;
1592 
1593 	val = search_val(mac, vid, tagged);
1594 	if (mac_vlan_lookup(ndev, val))
1595 		return -EEXIST;
1596 
1597 	ptr = kzalloc(sizeof(*ptr), GFP_KERNEL);
1598 	if (!ptr)
1599 		return -ENOMEM;
1600 
1601 	ptr->tagged = tagged;
1602 	ptr->macvlan = val;
1603 	ptr->ndev = ndev;
1604 	err = mlx5_vdpa_add_mac_vlan_rules(ndev, ndev->config.mac, ptr);
1605 	if (err)
1606 		goto err_add;
1607 
1608 	idx = hash_64(val, 8);
1609 	hlist_add_head(&ptr->hlist, &ndev->macvlan_hash[idx]);
1610 	return 0;
1611 
1612 err_add:
1613 	kfree(ptr);
1614 	return err;
1615 }
1616 
1617 static void mac_vlan_del(struct mlx5_vdpa_net *ndev, u8 *mac, u16 vlan, bool tagged)
1618 {
1619 	struct macvlan_node *ptr;
1620 
1621 	ptr = mac_vlan_lookup(ndev, search_val(mac, vlan, tagged));
1622 	if (!ptr)
1623 		return;
1624 
1625 	hlist_del(&ptr->hlist);
1626 	mlx5_vdpa_del_mac_vlan_rules(ndev, ptr);
1627 	remove_steering_counters(ndev, ptr);
1628 	kfree(ptr);
1629 }
1630 
1631 static void clear_mac_vlan_table(struct mlx5_vdpa_net *ndev)
1632 {
1633 	struct macvlan_node *pos;
1634 	struct hlist_node *n;
1635 	int i;
1636 
1637 	for (i = 0; i < MLX5V_MACVLAN_SIZE; i++) {
1638 		hlist_for_each_entry_safe(pos, n, &ndev->macvlan_hash[i], hlist) {
1639 			hlist_del(&pos->hlist);
1640 			mlx5_vdpa_del_mac_vlan_rules(ndev, pos);
1641 			remove_steering_counters(ndev, pos);
1642 			kfree(pos);
1643 		}
1644 	}
1645 }
1646 
1647 static int setup_steering(struct mlx5_vdpa_net *ndev)
1648 {
1649 	struct mlx5_flow_table_attr ft_attr = {};
1650 	struct mlx5_flow_namespace *ns;
1651 	int err;
1652 
1653 	ft_attr.max_fte = MAX_STEERING_ENT;
1654 	ft_attr.autogroup.max_num_groups = MAX_STEERING_GROUPS;
1655 
1656 	ns = mlx5_get_flow_namespace(ndev->mvdev.mdev, MLX5_FLOW_NAMESPACE_BYPASS);
1657 	if (!ns) {
1658 		mlx5_vdpa_warn(&ndev->mvdev, "failed to get flow namespace\n");
1659 		return -EOPNOTSUPP;
1660 	}
1661 
1662 	ndev->rxft = mlx5_create_auto_grouped_flow_table(ns, &ft_attr);
1663 	if (IS_ERR(ndev->rxft)) {
1664 		mlx5_vdpa_warn(&ndev->mvdev, "failed to create flow table\n");
1665 		return PTR_ERR(ndev->rxft);
1666 	}
1667 	mlx5_vdpa_add_rx_flow_table(ndev);
1668 
1669 	err = mac_vlan_add(ndev, ndev->config.mac, 0, false);
1670 	if (err)
1671 		goto err_add;
1672 
1673 	return 0;
1674 
1675 err_add:
1676 	mlx5_vdpa_remove_rx_flow_table(ndev);
1677 	mlx5_destroy_flow_table(ndev->rxft);
1678 	return err;
1679 }
1680 
1681 static void teardown_steering(struct mlx5_vdpa_net *ndev)
1682 {
1683 	clear_mac_vlan_table(ndev);
1684 	mlx5_vdpa_remove_rx_flow_table(ndev);
1685 	mlx5_destroy_flow_table(ndev->rxft);
1686 }
1687 
1688 static virtio_net_ctrl_ack handle_ctrl_mac(struct mlx5_vdpa_dev *mvdev, u8 cmd)
1689 {
1690 	struct mlx5_vdpa_net *ndev = to_mlx5_vdpa_ndev(mvdev);
1691 	struct mlx5_control_vq *cvq = &mvdev->cvq;
1692 	virtio_net_ctrl_ack status = VIRTIO_NET_ERR;
1693 	struct mlx5_core_dev *pfmdev;
1694 	size_t read;
1695 	u8 mac[ETH_ALEN], mac_back[ETH_ALEN];
1696 
1697 	pfmdev = pci_get_drvdata(pci_physfn(mvdev->mdev->pdev));
1698 	switch (cmd) {
1699 	case VIRTIO_NET_CTRL_MAC_ADDR_SET:
1700 		read = vringh_iov_pull_iotlb(&cvq->vring, &cvq->riov, (void *)mac, ETH_ALEN);
1701 		if (read != ETH_ALEN)
1702 			break;
1703 
1704 		if (!memcmp(ndev->config.mac, mac, 6)) {
1705 			status = VIRTIO_NET_OK;
1706 			break;
1707 		}
1708 
1709 		if (is_zero_ether_addr(mac))
1710 			break;
1711 
1712 		if (!is_zero_ether_addr(ndev->config.mac)) {
1713 			if (mlx5_mpfs_del_mac(pfmdev, ndev->config.mac)) {
1714 				mlx5_vdpa_warn(mvdev, "failed to delete old MAC %pM from MPFS table\n",
1715 					       ndev->config.mac);
1716 				break;
1717 			}
1718 		}
1719 
1720 		if (mlx5_mpfs_add_mac(pfmdev, mac)) {
1721 			mlx5_vdpa_warn(mvdev, "failed to insert new MAC %pM into MPFS table\n",
1722 				       mac);
1723 			break;
1724 		}
1725 
1726 		/* backup the original mac address so that if failed to add the forward rules
1727 		 * we could restore it
1728 		 */
1729 		memcpy(mac_back, ndev->config.mac, ETH_ALEN);
1730 
1731 		memcpy(ndev->config.mac, mac, ETH_ALEN);
1732 
1733 		/* Need recreate the flow table entry, so that the packet could forward back
1734 		 */
1735 		mac_vlan_del(ndev, mac_back, 0, false);
1736 
1737 		if (mac_vlan_add(ndev, ndev->config.mac, 0, false)) {
1738 			mlx5_vdpa_warn(mvdev, "failed to insert forward rules, try to restore\n");
1739 
1740 			/* Although it hardly run here, we still need double check */
1741 			if (is_zero_ether_addr(mac_back)) {
1742 				mlx5_vdpa_warn(mvdev, "restore mac failed: Original MAC is zero\n");
1743 				break;
1744 			}
1745 
1746 			/* Try to restore original mac address to MFPS table, and try to restore
1747 			 * the forward rule entry.
1748 			 */
1749 			if (mlx5_mpfs_del_mac(pfmdev, ndev->config.mac)) {
1750 				mlx5_vdpa_warn(mvdev, "restore mac failed: delete MAC %pM from MPFS table failed\n",
1751 					       ndev->config.mac);
1752 			}
1753 
1754 			if (mlx5_mpfs_add_mac(pfmdev, mac_back)) {
1755 				mlx5_vdpa_warn(mvdev, "restore mac failed: insert old MAC %pM into MPFS table failed\n",
1756 					       mac_back);
1757 			}
1758 
1759 			memcpy(ndev->config.mac, mac_back, ETH_ALEN);
1760 
1761 			if (mac_vlan_add(ndev, ndev->config.mac, 0, false))
1762 				mlx5_vdpa_warn(mvdev, "restore forward rules failed: insert forward rules failed\n");
1763 
1764 			break;
1765 		}
1766 
1767 		status = VIRTIO_NET_OK;
1768 		break;
1769 
1770 	default:
1771 		break;
1772 	}
1773 
1774 	return status;
1775 }
1776 
1777 static int change_num_qps(struct mlx5_vdpa_dev *mvdev, int newqps)
1778 {
1779 	struct mlx5_vdpa_net *ndev = to_mlx5_vdpa_ndev(mvdev);
1780 	int cur_qps = ndev->cur_num_vqs / 2;
1781 	int err;
1782 	int i;
1783 
1784 	if (cur_qps > newqps) {
1785 		err = modify_rqt(ndev, 2 * newqps);
1786 		if (err)
1787 			return err;
1788 
1789 		for (i = ndev->cur_num_vqs - 1; i >= 2 * newqps; i--)
1790 			teardown_vq(ndev, &ndev->vqs[i]);
1791 
1792 		ndev->cur_num_vqs = 2 * newqps;
1793 	} else {
1794 		ndev->cur_num_vqs = 2 * newqps;
1795 		for (i = cur_qps * 2; i < 2 * newqps; i++) {
1796 			err = setup_vq(ndev, &ndev->vqs[i]);
1797 			if (err)
1798 				goto clean_added;
1799 		}
1800 		err = modify_rqt(ndev, 2 * newqps);
1801 		if (err)
1802 			goto clean_added;
1803 	}
1804 	return 0;
1805 
1806 clean_added:
1807 	for (--i; i >= 2 * cur_qps; --i)
1808 		teardown_vq(ndev, &ndev->vqs[i]);
1809 
1810 	ndev->cur_num_vqs = 2 * cur_qps;
1811 
1812 	return err;
1813 }
1814 
1815 static virtio_net_ctrl_ack handle_ctrl_mq(struct mlx5_vdpa_dev *mvdev, u8 cmd)
1816 {
1817 	struct mlx5_vdpa_net *ndev = to_mlx5_vdpa_ndev(mvdev);
1818 	virtio_net_ctrl_ack status = VIRTIO_NET_ERR;
1819 	struct mlx5_control_vq *cvq = &mvdev->cvq;
1820 	struct virtio_net_ctrl_mq mq;
1821 	size_t read;
1822 	u16 newqps;
1823 
1824 	switch (cmd) {
1825 	case VIRTIO_NET_CTRL_MQ_VQ_PAIRS_SET:
1826 		/* This mq feature check aligns with pre-existing userspace
1827 		 * implementation.
1828 		 *
1829 		 * Without it, an untrusted driver could fake a multiqueue config
1830 		 * request down to a non-mq device that may cause kernel to
1831 		 * panic due to uninitialized resources for extra vqs. Even with
1832 		 * a well behaving guest driver, it is not expected to allow
1833 		 * changing the number of vqs on a non-mq device.
1834 		 */
1835 		if (!MLX5_FEATURE(mvdev, VIRTIO_NET_F_MQ))
1836 			break;
1837 
1838 		read = vringh_iov_pull_iotlb(&cvq->vring, &cvq->riov, (void *)&mq, sizeof(mq));
1839 		if (read != sizeof(mq))
1840 			break;
1841 
1842 		newqps = mlx5vdpa16_to_cpu(mvdev, mq.virtqueue_pairs);
1843 		if (newqps < VIRTIO_NET_CTRL_MQ_VQ_PAIRS_MIN ||
1844 		    newqps > ndev->rqt_size)
1845 			break;
1846 
1847 		if (ndev->cur_num_vqs == 2 * newqps) {
1848 			status = VIRTIO_NET_OK;
1849 			break;
1850 		}
1851 
1852 		if (!change_num_qps(mvdev, newqps))
1853 			status = VIRTIO_NET_OK;
1854 
1855 		break;
1856 	default:
1857 		break;
1858 	}
1859 
1860 	return status;
1861 }
1862 
1863 static virtio_net_ctrl_ack handle_ctrl_vlan(struct mlx5_vdpa_dev *mvdev, u8 cmd)
1864 {
1865 	struct mlx5_vdpa_net *ndev = to_mlx5_vdpa_ndev(mvdev);
1866 	virtio_net_ctrl_ack status = VIRTIO_NET_ERR;
1867 	struct mlx5_control_vq *cvq = &mvdev->cvq;
1868 	__virtio16 vlan;
1869 	size_t read;
1870 	u16 id;
1871 
1872 	if (!(ndev->mvdev.actual_features & BIT_ULL(VIRTIO_NET_F_CTRL_VLAN)))
1873 		return status;
1874 
1875 	switch (cmd) {
1876 	case VIRTIO_NET_CTRL_VLAN_ADD:
1877 		read = vringh_iov_pull_iotlb(&cvq->vring, &cvq->riov, &vlan, sizeof(vlan));
1878 		if (read != sizeof(vlan))
1879 			break;
1880 
1881 		id = mlx5vdpa16_to_cpu(mvdev, vlan);
1882 		if (mac_vlan_add(ndev, ndev->config.mac, id, true))
1883 			break;
1884 
1885 		status = VIRTIO_NET_OK;
1886 		break;
1887 	case VIRTIO_NET_CTRL_VLAN_DEL:
1888 		read = vringh_iov_pull_iotlb(&cvq->vring, &cvq->riov, &vlan, sizeof(vlan));
1889 		if (read != sizeof(vlan))
1890 			break;
1891 
1892 		id = mlx5vdpa16_to_cpu(mvdev, vlan);
1893 		mac_vlan_del(ndev, ndev->config.mac, id, true);
1894 		status = VIRTIO_NET_OK;
1895 		break;
1896 	default:
1897 		break;
1898 	}
1899 
1900 	return status;
1901 }
1902 
1903 static void mlx5_cvq_kick_handler(struct work_struct *work)
1904 {
1905 	virtio_net_ctrl_ack status = VIRTIO_NET_ERR;
1906 	struct virtio_net_ctrl_hdr ctrl;
1907 	struct mlx5_vdpa_wq_ent *wqent;
1908 	struct mlx5_vdpa_dev *mvdev;
1909 	struct mlx5_control_vq *cvq;
1910 	struct mlx5_vdpa_net *ndev;
1911 	size_t read, write;
1912 	int err;
1913 
1914 	wqent = container_of(work, struct mlx5_vdpa_wq_ent, work);
1915 	mvdev = wqent->mvdev;
1916 	ndev = to_mlx5_vdpa_ndev(mvdev);
1917 	cvq = &mvdev->cvq;
1918 
1919 	down_write(&ndev->reslock);
1920 
1921 	if (!(mvdev->status & VIRTIO_CONFIG_S_DRIVER_OK))
1922 		goto out;
1923 
1924 	if (!(ndev->mvdev.actual_features & BIT_ULL(VIRTIO_NET_F_CTRL_VQ)))
1925 		goto out;
1926 
1927 	if (!cvq->ready)
1928 		goto out;
1929 
1930 	while (true) {
1931 		err = vringh_getdesc_iotlb(&cvq->vring, &cvq->riov, &cvq->wiov, &cvq->head,
1932 					   GFP_ATOMIC);
1933 		if (err <= 0)
1934 			break;
1935 
1936 		read = vringh_iov_pull_iotlb(&cvq->vring, &cvq->riov, &ctrl, sizeof(ctrl));
1937 		if (read != sizeof(ctrl))
1938 			break;
1939 
1940 		cvq->received_desc++;
1941 		switch (ctrl.class) {
1942 		case VIRTIO_NET_CTRL_MAC:
1943 			status = handle_ctrl_mac(mvdev, ctrl.cmd);
1944 			break;
1945 		case VIRTIO_NET_CTRL_MQ:
1946 			status = handle_ctrl_mq(mvdev, ctrl.cmd);
1947 			break;
1948 		case VIRTIO_NET_CTRL_VLAN:
1949 			status = handle_ctrl_vlan(mvdev, ctrl.cmd);
1950 			break;
1951 		default:
1952 			break;
1953 		}
1954 
1955 		/* Make sure data is written before advancing index */
1956 		smp_wmb();
1957 
1958 		write = vringh_iov_push_iotlb(&cvq->vring, &cvq->wiov, &status, sizeof(status));
1959 		vringh_complete_iotlb(&cvq->vring, cvq->head, write);
1960 		vringh_kiov_cleanup(&cvq->riov);
1961 		vringh_kiov_cleanup(&cvq->wiov);
1962 
1963 		if (vringh_need_notify_iotlb(&cvq->vring))
1964 			vringh_notify(&cvq->vring);
1965 
1966 		cvq->completed_desc++;
1967 		queue_work(mvdev->wq, &wqent->work);
1968 		break;
1969 	}
1970 
1971 out:
1972 	up_write(&ndev->reslock);
1973 }
1974 
1975 static void mlx5_vdpa_kick_vq(struct vdpa_device *vdev, u16 idx)
1976 {
1977 	struct mlx5_vdpa_dev *mvdev = to_mvdev(vdev);
1978 	struct mlx5_vdpa_net *ndev = to_mlx5_vdpa_ndev(mvdev);
1979 	struct mlx5_vdpa_virtqueue *mvq;
1980 
1981 	if (!is_index_valid(mvdev, idx))
1982 		return;
1983 
1984 	if (unlikely(is_ctrl_vq_idx(mvdev, idx))) {
1985 		if (!mvdev->wq || !mvdev->cvq.ready)
1986 			return;
1987 
1988 		queue_work(mvdev->wq, &ndev->cvq_ent.work);
1989 		return;
1990 	}
1991 
1992 	mvq = &ndev->vqs[idx];
1993 	if (unlikely(!mvq->ready))
1994 		return;
1995 
1996 	iowrite16(idx, ndev->mvdev.res.kick_addr);
1997 }
1998 
1999 static int mlx5_vdpa_set_vq_address(struct vdpa_device *vdev, u16 idx, u64 desc_area,
2000 				    u64 driver_area, u64 device_area)
2001 {
2002 	struct mlx5_vdpa_dev *mvdev = to_mvdev(vdev);
2003 	struct mlx5_vdpa_net *ndev = to_mlx5_vdpa_ndev(mvdev);
2004 	struct mlx5_vdpa_virtqueue *mvq;
2005 
2006 	if (!is_index_valid(mvdev, idx))
2007 		return -EINVAL;
2008 
2009 	if (is_ctrl_vq_idx(mvdev, idx)) {
2010 		mvdev->cvq.desc_addr = desc_area;
2011 		mvdev->cvq.device_addr = device_area;
2012 		mvdev->cvq.driver_addr = driver_area;
2013 		return 0;
2014 	}
2015 
2016 	mvq = &ndev->vqs[idx];
2017 	mvq->desc_addr = desc_area;
2018 	mvq->device_addr = device_area;
2019 	mvq->driver_addr = driver_area;
2020 	return 0;
2021 }
2022 
2023 static void mlx5_vdpa_set_vq_num(struct vdpa_device *vdev, u16 idx, u32 num)
2024 {
2025 	struct mlx5_vdpa_dev *mvdev = to_mvdev(vdev);
2026 	struct mlx5_vdpa_net *ndev = to_mlx5_vdpa_ndev(mvdev);
2027 	struct mlx5_vdpa_virtqueue *mvq;
2028 
2029 	if (!is_index_valid(mvdev, idx) || is_ctrl_vq_idx(mvdev, idx))
2030 		return;
2031 
2032 	mvq = &ndev->vqs[idx];
2033 	mvq->num_ent = num;
2034 }
2035 
2036 static void mlx5_vdpa_set_vq_cb(struct vdpa_device *vdev, u16 idx, struct vdpa_callback *cb)
2037 {
2038 	struct mlx5_vdpa_dev *mvdev = to_mvdev(vdev);
2039 	struct mlx5_vdpa_net *ndev = to_mlx5_vdpa_ndev(mvdev);
2040 
2041 	ndev->event_cbs[idx] = *cb;
2042 	if (is_ctrl_vq_idx(mvdev, idx))
2043 		mvdev->cvq.event_cb = *cb;
2044 }
2045 
2046 static void mlx5_cvq_notify(struct vringh *vring)
2047 {
2048 	struct mlx5_control_vq *cvq = container_of(vring, struct mlx5_control_vq, vring);
2049 
2050 	if (!cvq->event_cb.callback)
2051 		return;
2052 
2053 	cvq->event_cb.callback(cvq->event_cb.private);
2054 }
2055 
2056 static void set_cvq_ready(struct mlx5_vdpa_dev *mvdev, bool ready)
2057 {
2058 	struct mlx5_control_vq *cvq = &mvdev->cvq;
2059 
2060 	cvq->ready = ready;
2061 	if (!ready)
2062 		return;
2063 
2064 	cvq->vring.notify = mlx5_cvq_notify;
2065 }
2066 
2067 static void mlx5_vdpa_set_vq_ready(struct vdpa_device *vdev, u16 idx, bool ready)
2068 {
2069 	struct mlx5_vdpa_dev *mvdev = to_mvdev(vdev);
2070 	struct mlx5_vdpa_net *ndev = to_mlx5_vdpa_ndev(mvdev);
2071 	struct mlx5_vdpa_virtqueue *mvq;
2072 	int err;
2073 
2074 	if (!mvdev->actual_features)
2075 		return;
2076 
2077 	if (!is_index_valid(mvdev, idx))
2078 		return;
2079 
2080 	if (is_ctrl_vq_idx(mvdev, idx)) {
2081 		set_cvq_ready(mvdev, ready);
2082 		return;
2083 	}
2084 
2085 	mvq = &ndev->vqs[idx];
2086 	if (!ready) {
2087 		suspend_vq(ndev, mvq);
2088 	} else {
2089 		err = modify_virtqueue(ndev, mvq, MLX5_VIRTIO_NET_Q_OBJECT_STATE_RDY);
2090 		if (err) {
2091 			mlx5_vdpa_warn(mvdev, "modify VQ %d to ready failed (%d)\n", idx, err);
2092 			ready = false;
2093 		}
2094 	}
2095 
2096 
2097 	mvq->ready = ready;
2098 }
2099 
2100 static bool mlx5_vdpa_get_vq_ready(struct vdpa_device *vdev, u16 idx)
2101 {
2102 	struct mlx5_vdpa_dev *mvdev = to_mvdev(vdev);
2103 	struct mlx5_vdpa_net *ndev = to_mlx5_vdpa_ndev(mvdev);
2104 
2105 	if (!is_index_valid(mvdev, idx))
2106 		return false;
2107 
2108 	if (is_ctrl_vq_idx(mvdev, idx))
2109 		return mvdev->cvq.ready;
2110 
2111 	return ndev->vqs[idx].ready;
2112 }
2113 
2114 static int mlx5_vdpa_set_vq_state(struct vdpa_device *vdev, u16 idx,
2115 				  const struct vdpa_vq_state *state)
2116 {
2117 	struct mlx5_vdpa_dev *mvdev = to_mvdev(vdev);
2118 	struct mlx5_vdpa_net *ndev = to_mlx5_vdpa_ndev(mvdev);
2119 	struct mlx5_vdpa_virtqueue *mvq;
2120 
2121 	if (!is_index_valid(mvdev, idx))
2122 		return -EINVAL;
2123 
2124 	if (is_ctrl_vq_idx(mvdev, idx)) {
2125 		mvdev->cvq.vring.last_avail_idx = state->split.avail_index;
2126 		return 0;
2127 	}
2128 
2129 	mvq = &ndev->vqs[idx];
2130 	if (mvq->fw_state == MLX5_VIRTIO_NET_Q_OBJECT_STATE_RDY) {
2131 		mlx5_vdpa_warn(mvdev, "can't modify available index\n");
2132 		return -EINVAL;
2133 	}
2134 
2135 	mvq->used_idx = state->split.avail_index;
2136 	mvq->avail_idx = state->split.avail_index;
2137 	return 0;
2138 }
2139 
2140 static int mlx5_vdpa_get_vq_state(struct vdpa_device *vdev, u16 idx, struct vdpa_vq_state *state)
2141 {
2142 	struct mlx5_vdpa_dev *mvdev = to_mvdev(vdev);
2143 	struct mlx5_vdpa_net *ndev = to_mlx5_vdpa_ndev(mvdev);
2144 	struct mlx5_vdpa_virtqueue *mvq;
2145 	struct mlx5_virtq_attr attr;
2146 	int err;
2147 
2148 	if (!is_index_valid(mvdev, idx))
2149 		return -EINVAL;
2150 
2151 	if (is_ctrl_vq_idx(mvdev, idx)) {
2152 		state->split.avail_index = mvdev->cvq.vring.last_avail_idx;
2153 		return 0;
2154 	}
2155 
2156 	mvq = &ndev->vqs[idx];
2157 	/* If the virtq object was destroyed, use the value saved at
2158 	 * the last minute of suspend_vq. This caters for userspace
2159 	 * that cares about emulating the index after vq is stopped.
2160 	 */
2161 	if (!mvq->initialized) {
2162 		/* Firmware returns a wrong value for the available index.
2163 		 * Since both values should be identical, we take the value of
2164 		 * used_idx which is reported correctly.
2165 		 */
2166 		state->split.avail_index = mvq->used_idx;
2167 		return 0;
2168 	}
2169 
2170 	err = query_virtqueue(ndev, mvq, &attr);
2171 	if (err) {
2172 		mlx5_vdpa_warn(mvdev, "failed to query virtqueue\n");
2173 		return err;
2174 	}
2175 	state->split.avail_index = attr.used_index;
2176 	return 0;
2177 }
2178 
2179 static u32 mlx5_vdpa_get_vq_align(struct vdpa_device *vdev)
2180 {
2181 	return PAGE_SIZE;
2182 }
2183 
2184 static u32 mlx5_vdpa_get_vq_group(struct vdpa_device *vdev, u16 idx)
2185 {
2186 	struct mlx5_vdpa_dev *mvdev = to_mvdev(vdev);
2187 
2188 	if (is_ctrl_vq_idx(mvdev, idx))
2189 		return MLX5_VDPA_CVQ_GROUP;
2190 
2191 	return MLX5_VDPA_DATAVQ_GROUP;
2192 }
2193 
2194 static u64 mlx_to_vritio_features(u16 dev_features)
2195 {
2196 	u64 result = 0;
2197 
2198 	if (dev_features & BIT_ULL(MLX5_VIRTIO_NET_F_MRG_RXBUF))
2199 		result |= BIT_ULL(VIRTIO_NET_F_MRG_RXBUF);
2200 	if (dev_features & BIT_ULL(MLX5_VIRTIO_NET_F_HOST_ECN))
2201 		result |= BIT_ULL(VIRTIO_NET_F_HOST_ECN);
2202 	if (dev_features & BIT_ULL(MLX5_VIRTIO_NET_F_GUEST_ECN))
2203 		result |= BIT_ULL(VIRTIO_NET_F_GUEST_ECN);
2204 	if (dev_features & BIT_ULL(MLX5_VIRTIO_NET_F_GUEST_TSO6))
2205 		result |= BIT_ULL(VIRTIO_NET_F_GUEST_TSO6);
2206 	if (dev_features & BIT_ULL(MLX5_VIRTIO_NET_F_GUEST_TSO4))
2207 		result |= BIT_ULL(VIRTIO_NET_F_GUEST_TSO4);
2208 	if (dev_features & BIT_ULL(MLX5_VIRTIO_NET_F_GUEST_CSUM))
2209 		result |= BIT_ULL(VIRTIO_NET_F_GUEST_CSUM);
2210 	if (dev_features & BIT_ULL(MLX5_VIRTIO_NET_F_CSUM))
2211 		result |= BIT_ULL(VIRTIO_NET_F_CSUM);
2212 	if (dev_features & BIT_ULL(MLX5_VIRTIO_NET_F_HOST_TSO6))
2213 		result |= BIT_ULL(VIRTIO_NET_F_HOST_TSO6);
2214 	if (dev_features & BIT_ULL(MLX5_VIRTIO_NET_F_HOST_TSO4))
2215 		result |= BIT_ULL(VIRTIO_NET_F_HOST_TSO4);
2216 
2217 	return result;
2218 }
2219 
2220 static u64 get_supported_features(struct mlx5_core_dev *mdev)
2221 {
2222 	u64 mlx_vdpa_features = 0;
2223 	u16 dev_features;
2224 
2225 	dev_features = MLX5_CAP_DEV_VDPA_EMULATION(mdev, device_features_bits_mask);
2226 	mlx_vdpa_features |= mlx_to_vritio_features(dev_features);
2227 	if (MLX5_CAP_DEV_VDPA_EMULATION(mdev, virtio_version_1_0))
2228 		mlx_vdpa_features |= BIT_ULL(VIRTIO_F_VERSION_1);
2229 	mlx_vdpa_features |= BIT_ULL(VIRTIO_F_ACCESS_PLATFORM);
2230 	mlx_vdpa_features |= BIT_ULL(VIRTIO_NET_F_CTRL_VQ);
2231 	mlx_vdpa_features |= BIT_ULL(VIRTIO_NET_F_CTRL_MAC_ADDR);
2232 	mlx_vdpa_features |= BIT_ULL(VIRTIO_NET_F_MQ);
2233 	mlx_vdpa_features |= BIT_ULL(VIRTIO_NET_F_STATUS);
2234 	mlx_vdpa_features |= BIT_ULL(VIRTIO_NET_F_MTU);
2235 	mlx_vdpa_features |= BIT_ULL(VIRTIO_NET_F_CTRL_VLAN);
2236 	mlx_vdpa_features |= BIT_ULL(VIRTIO_NET_F_MAC);
2237 
2238 	return mlx_vdpa_features;
2239 }
2240 
2241 static u64 mlx5_vdpa_get_device_features(struct vdpa_device *vdev)
2242 {
2243 	struct mlx5_vdpa_dev *mvdev = to_mvdev(vdev);
2244 	struct mlx5_vdpa_net *ndev = to_mlx5_vdpa_ndev(mvdev);
2245 
2246 	print_features(mvdev, ndev->mvdev.mlx_features, false);
2247 	return ndev->mvdev.mlx_features;
2248 }
2249 
2250 static int verify_driver_features(struct mlx5_vdpa_dev *mvdev, u64 features)
2251 {
2252 	/* Minimum features to expect */
2253 	if (!(features & BIT_ULL(VIRTIO_F_ACCESS_PLATFORM)))
2254 		return -EOPNOTSUPP;
2255 
2256 	/* Double check features combination sent down by the driver.
2257 	 * Fail invalid features due to absence of the depended feature.
2258 	 *
2259 	 * Per VIRTIO v1.1 specification, section 5.1.3.1 Feature bit
2260 	 * requirements: "VIRTIO_NET_F_MQ Requires VIRTIO_NET_F_CTRL_VQ".
2261 	 * By failing the invalid features sent down by untrusted drivers,
2262 	 * we're assured the assumption made upon is_index_valid() and
2263 	 * is_ctrl_vq_idx() will not be compromised.
2264 	 */
2265 	if ((features & (BIT_ULL(VIRTIO_NET_F_MQ) | BIT_ULL(VIRTIO_NET_F_CTRL_VQ))) ==
2266             BIT_ULL(VIRTIO_NET_F_MQ))
2267 		return -EINVAL;
2268 
2269 	return 0;
2270 }
2271 
2272 static int setup_virtqueues(struct mlx5_vdpa_dev *mvdev)
2273 {
2274 	struct mlx5_vdpa_net *ndev = to_mlx5_vdpa_ndev(mvdev);
2275 	int err;
2276 	int i;
2277 
2278 	for (i = 0; i < mvdev->max_vqs; i++) {
2279 		err = setup_vq(ndev, &ndev->vqs[i]);
2280 		if (err)
2281 			goto err_vq;
2282 	}
2283 
2284 	return 0;
2285 
2286 err_vq:
2287 	for (--i; i >= 0; i--)
2288 		teardown_vq(ndev, &ndev->vqs[i]);
2289 
2290 	return err;
2291 }
2292 
2293 static void teardown_virtqueues(struct mlx5_vdpa_net *ndev)
2294 {
2295 	struct mlx5_vdpa_virtqueue *mvq;
2296 	int i;
2297 
2298 	for (i = ndev->mvdev.max_vqs - 1; i >= 0; i--) {
2299 		mvq = &ndev->vqs[i];
2300 		if (!mvq->initialized)
2301 			continue;
2302 
2303 		teardown_vq(ndev, mvq);
2304 	}
2305 }
2306 
2307 static void update_cvq_info(struct mlx5_vdpa_dev *mvdev)
2308 {
2309 	if (MLX5_FEATURE(mvdev, VIRTIO_NET_F_CTRL_VQ)) {
2310 		if (MLX5_FEATURE(mvdev, VIRTIO_NET_F_MQ)) {
2311 			/* MQ supported. CVQ index is right above the last data virtqueue's */
2312 			mvdev->max_idx = mvdev->max_vqs;
2313 		} else {
2314 			/* Only CVQ supportted. data virtqueues occupy indices 0 and 1.
2315 			 * CVQ gets index 2
2316 			 */
2317 			mvdev->max_idx = 2;
2318 		}
2319 	} else {
2320 		/* Two data virtqueues only: one for rx and one for tx */
2321 		mvdev->max_idx = 1;
2322 	}
2323 }
2324 
2325 static u8 query_vport_state(struct mlx5_core_dev *mdev, u8 opmod, u16 vport)
2326 {
2327 	u32 out[MLX5_ST_SZ_DW(query_vport_state_out)] = {};
2328 	u32 in[MLX5_ST_SZ_DW(query_vport_state_in)] = {};
2329 	int err;
2330 
2331 	MLX5_SET(query_vport_state_in, in, opcode, MLX5_CMD_OP_QUERY_VPORT_STATE);
2332 	MLX5_SET(query_vport_state_in, in, op_mod, opmod);
2333 	MLX5_SET(query_vport_state_in, in, vport_number, vport);
2334 	if (vport)
2335 		MLX5_SET(query_vport_state_in, in, other_vport, 1);
2336 
2337 	err = mlx5_cmd_exec_inout(mdev, query_vport_state, in, out);
2338 	if (err)
2339 		return 0;
2340 
2341 	return MLX5_GET(query_vport_state_out, out, state);
2342 }
2343 
2344 static bool get_link_state(struct mlx5_vdpa_dev *mvdev)
2345 {
2346 	if (query_vport_state(mvdev->mdev, MLX5_VPORT_STATE_OP_MOD_VNIC_VPORT, 0) ==
2347 	    VPORT_STATE_UP)
2348 		return true;
2349 
2350 	return false;
2351 }
2352 
2353 static void update_carrier(struct work_struct *work)
2354 {
2355 	struct mlx5_vdpa_wq_ent *wqent;
2356 	struct mlx5_vdpa_dev *mvdev;
2357 	struct mlx5_vdpa_net *ndev;
2358 
2359 	wqent = container_of(work, struct mlx5_vdpa_wq_ent, work);
2360 	mvdev = wqent->mvdev;
2361 	ndev = to_mlx5_vdpa_ndev(mvdev);
2362 	if (get_link_state(mvdev))
2363 		ndev->config.status |= cpu_to_mlx5vdpa16(mvdev, VIRTIO_NET_S_LINK_UP);
2364 	else
2365 		ndev->config.status &= cpu_to_mlx5vdpa16(mvdev, ~VIRTIO_NET_S_LINK_UP);
2366 
2367 	if (ndev->config_cb.callback)
2368 		ndev->config_cb.callback(ndev->config_cb.private);
2369 
2370 	kfree(wqent);
2371 }
2372 
2373 static int queue_link_work(struct mlx5_vdpa_net *ndev)
2374 {
2375 	struct mlx5_vdpa_wq_ent *wqent;
2376 
2377 	wqent = kzalloc(sizeof(*wqent), GFP_ATOMIC);
2378 	if (!wqent)
2379 		return -ENOMEM;
2380 
2381 	wqent->mvdev = &ndev->mvdev;
2382 	INIT_WORK(&wqent->work, update_carrier);
2383 	queue_work(ndev->mvdev.wq, &wqent->work);
2384 	return 0;
2385 }
2386 
2387 static int event_handler(struct notifier_block *nb, unsigned long event, void *param)
2388 {
2389 	struct mlx5_vdpa_net *ndev = container_of(nb, struct mlx5_vdpa_net, nb);
2390 	struct mlx5_eqe *eqe = param;
2391 	int ret = NOTIFY_DONE;
2392 
2393 	if (event == MLX5_EVENT_TYPE_PORT_CHANGE) {
2394 		switch (eqe->sub_type) {
2395 		case MLX5_PORT_CHANGE_SUBTYPE_DOWN:
2396 		case MLX5_PORT_CHANGE_SUBTYPE_ACTIVE:
2397 			if (queue_link_work(ndev))
2398 				return NOTIFY_DONE;
2399 
2400 			ret = NOTIFY_OK;
2401 			break;
2402 		default:
2403 			return NOTIFY_DONE;
2404 		}
2405 		return ret;
2406 	}
2407 	return ret;
2408 }
2409 
2410 static void register_link_notifier(struct mlx5_vdpa_net *ndev)
2411 {
2412 	if (!(ndev->mvdev.actual_features & BIT_ULL(VIRTIO_NET_F_STATUS)))
2413 		return;
2414 
2415 	ndev->nb.notifier_call = event_handler;
2416 	mlx5_notifier_register(ndev->mvdev.mdev, &ndev->nb);
2417 	ndev->nb_registered = true;
2418 	queue_link_work(ndev);
2419 }
2420 
2421 static void unregister_link_notifier(struct mlx5_vdpa_net *ndev)
2422 {
2423 	if (!ndev->nb_registered)
2424 		return;
2425 
2426 	ndev->nb_registered = false;
2427 	mlx5_notifier_unregister(ndev->mvdev.mdev, &ndev->nb);
2428 	if (ndev->mvdev.wq)
2429 		flush_workqueue(ndev->mvdev.wq);
2430 }
2431 
2432 static int mlx5_vdpa_set_driver_features(struct vdpa_device *vdev, u64 features)
2433 {
2434 	struct mlx5_vdpa_dev *mvdev = to_mvdev(vdev);
2435 	struct mlx5_vdpa_net *ndev = to_mlx5_vdpa_ndev(mvdev);
2436 	int err;
2437 
2438 	print_features(mvdev, features, true);
2439 
2440 	err = verify_driver_features(mvdev, features);
2441 	if (err)
2442 		return err;
2443 
2444 	ndev->mvdev.actual_features = features & ndev->mvdev.mlx_features;
2445 	if (ndev->mvdev.actual_features & BIT_ULL(VIRTIO_NET_F_MQ))
2446 		ndev->rqt_size = mlx5vdpa16_to_cpu(mvdev, ndev->config.max_virtqueue_pairs);
2447 	else
2448 		ndev->rqt_size = 1;
2449 
2450 	ndev->cur_num_vqs = 2 * ndev->rqt_size;
2451 
2452 	update_cvq_info(mvdev);
2453 	return err;
2454 }
2455 
2456 static void mlx5_vdpa_set_config_cb(struct vdpa_device *vdev, struct vdpa_callback *cb)
2457 {
2458 	struct mlx5_vdpa_dev *mvdev = to_mvdev(vdev);
2459 	struct mlx5_vdpa_net *ndev = to_mlx5_vdpa_ndev(mvdev);
2460 
2461 	ndev->config_cb = *cb;
2462 }
2463 
2464 #define MLX5_VDPA_MAX_VQ_ENTRIES 256
2465 static u16 mlx5_vdpa_get_vq_num_max(struct vdpa_device *vdev)
2466 {
2467 	return MLX5_VDPA_MAX_VQ_ENTRIES;
2468 }
2469 
2470 static u32 mlx5_vdpa_get_device_id(struct vdpa_device *vdev)
2471 {
2472 	return VIRTIO_ID_NET;
2473 }
2474 
2475 static u32 mlx5_vdpa_get_vendor_id(struct vdpa_device *vdev)
2476 {
2477 	return PCI_VENDOR_ID_MELLANOX;
2478 }
2479 
2480 static u8 mlx5_vdpa_get_status(struct vdpa_device *vdev)
2481 {
2482 	struct mlx5_vdpa_dev *mvdev = to_mvdev(vdev);
2483 	struct mlx5_vdpa_net *ndev = to_mlx5_vdpa_ndev(mvdev);
2484 
2485 	print_status(mvdev, ndev->mvdev.status, false);
2486 	return ndev->mvdev.status;
2487 }
2488 
2489 static int save_channel_info(struct mlx5_vdpa_net *ndev, struct mlx5_vdpa_virtqueue *mvq)
2490 {
2491 	struct mlx5_vq_restore_info *ri = &mvq->ri;
2492 	struct mlx5_virtq_attr attr = {};
2493 	int err;
2494 
2495 	if (mvq->initialized) {
2496 		err = query_virtqueue(ndev, mvq, &attr);
2497 		if (err)
2498 			return err;
2499 	}
2500 
2501 	ri->avail_index = attr.available_index;
2502 	ri->used_index = attr.used_index;
2503 	ri->ready = mvq->ready;
2504 	ri->num_ent = mvq->num_ent;
2505 	ri->desc_addr = mvq->desc_addr;
2506 	ri->device_addr = mvq->device_addr;
2507 	ri->driver_addr = mvq->driver_addr;
2508 	ri->restore = true;
2509 	return 0;
2510 }
2511 
2512 static int save_channels_info(struct mlx5_vdpa_net *ndev)
2513 {
2514 	int i;
2515 
2516 	for (i = 0; i < ndev->mvdev.max_vqs; i++) {
2517 		memset(&ndev->vqs[i].ri, 0, sizeof(ndev->vqs[i].ri));
2518 		save_channel_info(ndev, &ndev->vqs[i]);
2519 	}
2520 	return 0;
2521 }
2522 
2523 static void mlx5_clear_vqs(struct mlx5_vdpa_net *ndev)
2524 {
2525 	int i;
2526 
2527 	for (i = 0; i < ndev->mvdev.max_vqs; i++)
2528 		memset(&ndev->vqs[i], 0, offsetof(struct mlx5_vdpa_virtqueue, ri));
2529 }
2530 
2531 static void restore_channels_info(struct mlx5_vdpa_net *ndev)
2532 {
2533 	struct mlx5_vdpa_virtqueue *mvq;
2534 	struct mlx5_vq_restore_info *ri;
2535 	int i;
2536 
2537 	mlx5_clear_vqs(ndev);
2538 	init_mvqs(ndev);
2539 	for (i = 0; i < ndev->mvdev.max_vqs; i++) {
2540 		mvq = &ndev->vqs[i];
2541 		ri = &mvq->ri;
2542 		if (!ri->restore)
2543 			continue;
2544 
2545 		mvq->avail_idx = ri->avail_index;
2546 		mvq->used_idx = ri->used_index;
2547 		mvq->ready = ri->ready;
2548 		mvq->num_ent = ri->num_ent;
2549 		mvq->desc_addr = ri->desc_addr;
2550 		mvq->device_addr = ri->device_addr;
2551 		mvq->driver_addr = ri->driver_addr;
2552 	}
2553 }
2554 
2555 static int mlx5_vdpa_change_map(struct mlx5_vdpa_dev *mvdev,
2556 				struct vhost_iotlb *iotlb, unsigned int asid)
2557 {
2558 	struct mlx5_vdpa_net *ndev = to_mlx5_vdpa_ndev(mvdev);
2559 	int err;
2560 
2561 	suspend_vqs(ndev);
2562 	err = save_channels_info(ndev);
2563 	if (err)
2564 		goto err_mr;
2565 
2566 	teardown_driver(ndev);
2567 	mlx5_vdpa_destroy_mr(mvdev);
2568 	err = mlx5_vdpa_create_mr(mvdev, iotlb, asid);
2569 	if (err)
2570 		goto err_mr;
2571 
2572 	if (!(mvdev->status & VIRTIO_CONFIG_S_DRIVER_OK) || mvdev->suspended)
2573 		goto err_mr;
2574 
2575 	restore_channels_info(ndev);
2576 	err = setup_driver(mvdev);
2577 	if (err)
2578 		goto err_setup;
2579 
2580 	return 0;
2581 
2582 err_setup:
2583 	mlx5_vdpa_destroy_mr(mvdev);
2584 err_mr:
2585 	return err;
2586 }
2587 
2588 /* reslock must be held for this function */
2589 static int setup_driver(struct mlx5_vdpa_dev *mvdev)
2590 {
2591 	struct mlx5_vdpa_net *ndev = to_mlx5_vdpa_ndev(mvdev);
2592 	int err;
2593 
2594 	WARN_ON(!rwsem_is_locked(&ndev->reslock));
2595 
2596 	if (ndev->setup) {
2597 		mlx5_vdpa_warn(mvdev, "setup driver called for already setup driver\n");
2598 		err = 0;
2599 		goto out;
2600 	}
2601 	mlx5_vdpa_add_debugfs(ndev);
2602 	err = setup_virtqueues(mvdev);
2603 	if (err) {
2604 		mlx5_vdpa_warn(mvdev, "setup_virtqueues\n");
2605 		goto err_setup;
2606 	}
2607 
2608 	err = create_rqt(ndev);
2609 	if (err) {
2610 		mlx5_vdpa_warn(mvdev, "create_rqt\n");
2611 		goto err_rqt;
2612 	}
2613 
2614 	err = create_tir(ndev);
2615 	if (err) {
2616 		mlx5_vdpa_warn(mvdev, "create_tir\n");
2617 		goto err_tir;
2618 	}
2619 
2620 	err = setup_steering(ndev);
2621 	if (err) {
2622 		mlx5_vdpa_warn(mvdev, "setup_steering\n");
2623 		goto err_fwd;
2624 	}
2625 	ndev->setup = true;
2626 
2627 	return 0;
2628 
2629 err_fwd:
2630 	destroy_tir(ndev);
2631 err_tir:
2632 	destroy_rqt(ndev);
2633 err_rqt:
2634 	teardown_virtqueues(ndev);
2635 err_setup:
2636 	mlx5_vdpa_remove_debugfs(ndev->debugfs);
2637 out:
2638 	return err;
2639 }
2640 
2641 /* reslock must be held for this function */
2642 static void teardown_driver(struct mlx5_vdpa_net *ndev)
2643 {
2644 
2645 	WARN_ON(!rwsem_is_locked(&ndev->reslock));
2646 
2647 	if (!ndev->setup)
2648 		return;
2649 
2650 	mlx5_vdpa_remove_debugfs(ndev->debugfs);
2651 	ndev->debugfs = NULL;
2652 	teardown_steering(ndev);
2653 	destroy_tir(ndev);
2654 	destroy_rqt(ndev);
2655 	teardown_virtqueues(ndev);
2656 	ndev->setup = false;
2657 }
2658 
2659 static void clear_vqs_ready(struct mlx5_vdpa_net *ndev)
2660 {
2661 	int i;
2662 
2663 	for (i = 0; i < ndev->mvdev.max_vqs; i++)
2664 		ndev->vqs[i].ready = false;
2665 
2666 	ndev->mvdev.cvq.ready = false;
2667 }
2668 
2669 static int setup_cvq_vring(struct mlx5_vdpa_dev *mvdev)
2670 {
2671 	struct mlx5_control_vq *cvq = &mvdev->cvq;
2672 	int err = 0;
2673 
2674 	if (mvdev->actual_features & BIT_ULL(VIRTIO_NET_F_CTRL_VQ))
2675 		err = vringh_init_iotlb(&cvq->vring, mvdev->actual_features,
2676 					MLX5_CVQ_MAX_ENT, false,
2677 					(struct vring_desc *)(uintptr_t)cvq->desc_addr,
2678 					(struct vring_avail *)(uintptr_t)cvq->driver_addr,
2679 					(struct vring_used *)(uintptr_t)cvq->device_addr);
2680 
2681 	return err;
2682 }
2683 
2684 static void mlx5_vdpa_set_status(struct vdpa_device *vdev, u8 status)
2685 {
2686 	struct mlx5_vdpa_dev *mvdev = to_mvdev(vdev);
2687 	struct mlx5_vdpa_net *ndev = to_mlx5_vdpa_ndev(mvdev);
2688 	int err;
2689 
2690 	print_status(mvdev, status, true);
2691 
2692 	down_write(&ndev->reslock);
2693 
2694 	if ((status ^ ndev->mvdev.status) & VIRTIO_CONFIG_S_DRIVER_OK) {
2695 		if (status & VIRTIO_CONFIG_S_DRIVER_OK) {
2696 			err = setup_cvq_vring(mvdev);
2697 			if (err) {
2698 				mlx5_vdpa_warn(mvdev, "failed to setup control VQ vring\n");
2699 				goto err_setup;
2700 			}
2701 			register_link_notifier(ndev);
2702 			err = setup_driver(mvdev);
2703 			if (err) {
2704 				mlx5_vdpa_warn(mvdev, "failed to setup driver\n");
2705 				goto err_driver;
2706 			}
2707 		} else {
2708 			mlx5_vdpa_warn(mvdev, "did not expect DRIVER_OK to be cleared\n");
2709 			goto err_clear;
2710 		}
2711 	}
2712 
2713 	ndev->mvdev.status = status;
2714 	up_write(&ndev->reslock);
2715 	return;
2716 
2717 err_driver:
2718 	unregister_link_notifier(ndev);
2719 err_setup:
2720 	mlx5_vdpa_destroy_mr(&ndev->mvdev);
2721 	ndev->mvdev.status |= VIRTIO_CONFIG_S_FAILED;
2722 err_clear:
2723 	up_write(&ndev->reslock);
2724 }
2725 
2726 static void init_group_to_asid_map(struct mlx5_vdpa_dev *mvdev)
2727 {
2728 	int i;
2729 
2730 	/* default mapping all groups are mapped to asid 0 */
2731 	for (i = 0; i < MLX5_VDPA_NUMVQ_GROUPS; i++)
2732 		mvdev->group2asid[i] = 0;
2733 }
2734 
2735 static int mlx5_vdpa_reset(struct vdpa_device *vdev)
2736 {
2737 	struct mlx5_vdpa_dev *mvdev = to_mvdev(vdev);
2738 	struct mlx5_vdpa_net *ndev = to_mlx5_vdpa_ndev(mvdev);
2739 
2740 	print_status(mvdev, 0, true);
2741 	mlx5_vdpa_info(mvdev, "performing device reset\n");
2742 
2743 	down_write(&ndev->reslock);
2744 	unregister_link_notifier(ndev);
2745 	teardown_driver(ndev);
2746 	clear_vqs_ready(ndev);
2747 	mlx5_vdpa_destroy_mr(&ndev->mvdev);
2748 	ndev->mvdev.status = 0;
2749 	ndev->mvdev.suspended = false;
2750 	ndev->cur_num_vqs = 0;
2751 	ndev->mvdev.cvq.received_desc = 0;
2752 	ndev->mvdev.cvq.completed_desc = 0;
2753 	memset(ndev->event_cbs, 0, sizeof(*ndev->event_cbs) * (mvdev->max_vqs + 1));
2754 	ndev->mvdev.actual_features = 0;
2755 	init_group_to_asid_map(mvdev);
2756 	++mvdev->generation;
2757 
2758 	if (MLX5_CAP_GEN(mvdev->mdev, umem_uid_0)) {
2759 		if (mlx5_vdpa_create_mr(mvdev, NULL, 0))
2760 			mlx5_vdpa_warn(mvdev, "create MR failed\n");
2761 	}
2762 	up_write(&ndev->reslock);
2763 
2764 	return 0;
2765 }
2766 
2767 static size_t mlx5_vdpa_get_config_size(struct vdpa_device *vdev)
2768 {
2769 	return sizeof(struct virtio_net_config);
2770 }
2771 
2772 static void mlx5_vdpa_get_config(struct vdpa_device *vdev, unsigned int offset, void *buf,
2773 				 unsigned int len)
2774 {
2775 	struct mlx5_vdpa_dev *mvdev = to_mvdev(vdev);
2776 	struct mlx5_vdpa_net *ndev = to_mlx5_vdpa_ndev(mvdev);
2777 
2778 	if (offset + len <= sizeof(struct virtio_net_config))
2779 		memcpy(buf, (u8 *)&ndev->config + offset, len);
2780 }
2781 
2782 static void mlx5_vdpa_set_config(struct vdpa_device *vdev, unsigned int offset, const void *buf,
2783 				 unsigned int len)
2784 {
2785 	/* not supported */
2786 }
2787 
2788 static u32 mlx5_vdpa_get_generation(struct vdpa_device *vdev)
2789 {
2790 	struct mlx5_vdpa_dev *mvdev = to_mvdev(vdev);
2791 
2792 	return mvdev->generation;
2793 }
2794 
2795 static int set_map_data(struct mlx5_vdpa_dev *mvdev, struct vhost_iotlb *iotlb,
2796 			unsigned int asid)
2797 {
2798 	bool change_map;
2799 	int err;
2800 
2801 	err = mlx5_vdpa_handle_set_map(mvdev, iotlb, &change_map, asid);
2802 	if (err) {
2803 		mlx5_vdpa_warn(mvdev, "set map failed(%d)\n", err);
2804 		return err;
2805 	}
2806 
2807 	if (change_map)
2808 		err = mlx5_vdpa_change_map(mvdev, iotlb, asid);
2809 
2810 	return err;
2811 }
2812 
2813 static int mlx5_vdpa_set_map(struct vdpa_device *vdev, unsigned int asid,
2814 			     struct vhost_iotlb *iotlb)
2815 {
2816 	struct mlx5_vdpa_dev *mvdev = to_mvdev(vdev);
2817 	struct mlx5_vdpa_net *ndev = to_mlx5_vdpa_ndev(mvdev);
2818 	int err = -EINVAL;
2819 
2820 	down_write(&ndev->reslock);
2821 	err = set_map_data(mvdev, iotlb, asid);
2822 	up_write(&ndev->reslock);
2823 	return err;
2824 }
2825 
2826 static struct device *mlx5_get_vq_dma_dev(struct vdpa_device *vdev, u16 idx)
2827 {
2828 	struct mlx5_vdpa_dev *mvdev = to_mvdev(vdev);
2829 
2830 	if (is_ctrl_vq_idx(mvdev, idx))
2831 		return &vdev->dev;
2832 
2833 	return mvdev->vdev.dma_dev;
2834 }
2835 
2836 static void mlx5_vdpa_free(struct vdpa_device *vdev)
2837 {
2838 	struct mlx5_vdpa_dev *mvdev = to_mvdev(vdev);
2839 	struct mlx5_core_dev *pfmdev;
2840 	struct mlx5_vdpa_net *ndev;
2841 
2842 	ndev = to_mlx5_vdpa_ndev(mvdev);
2843 
2844 	free_resources(ndev);
2845 	mlx5_vdpa_destroy_mr(mvdev);
2846 	if (!is_zero_ether_addr(ndev->config.mac)) {
2847 		pfmdev = pci_get_drvdata(pci_physfn(mvdev->mdev->pdev));
2848 		mlx5_mpfs_del_mac(pfmdev, ndev->config.mac);
2849 	}
2850 	mlx5_vdpa_free_resources(&ndev->mvdev);
2851 	kfree(ndev->event_cbs);
2852 	kfree(ndev->vqs);
2853 }
2854 
2855 static struct vdpa_notification_area mlx5_get_vq_notification(struct vdpa_device *vdev, u16 idx)
2856 {
2857 	struct mlx5_vdpa_dev *mvdev = to_mvdev(vdev);
2858 	struct vdpa_notification_area ret = {};
2859 	struct mlx5_vdpa_net *ndev;
2860 	phys_addr_t addr;
2861 
2862 	if (!is_index_valid(mvdev, idx) || is_ctrl_vq_idx(mvdev, idx))
2863 		return ret;
2864 
2865 	/* If SF BAR size is smaller than PAGE_SIZE, do not use direct
2866 	 * notification to avoid the risk of mapping pages that contain BAR of more
2867 	 * than one SF
2868 	 */
2869 	if (MLX5_CAP_GEN(mvdev->mdev, log_min_sf_size) + 12 < PAGE_SHIFT)
2870 		return ret;
2871 
2872 	ndev = to_mlx5_vdpa_ndev(mvdev);
2873 	addr = (phys_addr_t)ndev->mvdev.res.phys_kick_addr;
2874 	ret.addr = addr;
2875 	ret.size = PAGE_SIZE;
2876 	return ret;
2877 }
2878 
2879 static int mlx5_get_vq_irq(struct vdpa_device *vdv, u16 idx)
2880 {
2881 	return -EOPNOTSUPP;
2882 }
2883 
2884 static u64 mlx5_vdpa_get_driver_features(struct vdpa_device *vdev)
2885 {
2886 	struct mlx5_vdpa_dev *mvdev = to_mvdev(vdev);
2887 
2888 	return mvdev->actual_features;
2889 }
2890 
2891 static int counter_set_query(struct mlx5_vdpa_net *ndev, struct mlx5_vdpa_virtqueue *mvq,
2892 			     u64 *received_desc, u64 *completed_desc)
2893 {
2894 	u32 in[MLX5_ST_SZ_DW(query_virtio_q_counters_in)] = {};
2895 	u32 out[MLX5_ST_SZ_DW(query_virtio_q_counters_out)] = {};
2896 	void *cmd_hdr;
2897 	void *ctx;
2898 	int err;
2899 
2900 	if (!counters_supported(&ndev->mvdev))
2901 		return -EOPNOTSUPP;
2902 
2903 	if (mvq->fw_state != MLX5_VIRTIO_NET_Q_OBJECT_STATE_RDY)
2904 		return -EAGAIN;
2905 
2906 	cmd_hdr = MLX5_ADDR_OF(query_virtio_q_counters_in, in, hdr);
2907 
2908 	MLX5_SET(general_obj_in_cmd_hdr, cmd_hdr, opcode, MLX5_CMD_OP_QUERY_GENERAL_OBJECT);
2909 	MLX5_SET(general_obj_in_cmd_hdr, cmd_hdr, obj_type, MLX5_OBJ_TYPE_VIRTIO_Q_COUNTERS);
2910 	MLX5_SET(general_obj_in_cmd_hdr, cmd_hdr, uid, ndev->mvdev.res.uid);
2911 	MLX5_SET(general_obj_in_cmd_hdr, cmd_hdr, obj_id, mvq->counter_set_id);
2912 
2913 	err = mlx5_cmd_exec(ndev->mvdev.mdev, in, sizeof(in), out, sizeof(out));
2914 	if (err)
2915 		return err;
2916 
2917 	ctx = MLX5_ADDR_OF(query_virtio_q_counters_out, out, counters);
2918 	*received_desc = MLX5_GET64(virtio_q_counters, ctx, received_desc);
2919 	*completed_desc = MLX5_GET64(virtio_q_counters, ctx, completed_desc);
2920 	return 0;
2921 }
2922 
2923 static int mlx5_vdpa_get_vendor_vq_stats(struct vdpa_device *vdev, u16 idx,
2924 					 struct sk_buff *msg,
2925 					 struct netlink_ext_ack *extack)
2926 {
2927 	struct mlx5_vdpa_dev *mvdev = to_mvdev(vdev);
2928 	struct mlx5_vdpa_net *ndev = to_mlx5_vdpa_ndev(mvdev);
2929 	struct mlx5_vdpa_virtqueue *mvq;
2930 	struct mlx5_control_vq *cvq;
2931 	u64 received_desc;
2932 	u64 completed_desc;
2933 	int err = 0;
2934 
2935 	down_read(&ndev->reslock);
2936 	if (!is_index_valid(mvdev, idx)) {
2937 		NL_SET_ERR_MSG_MOD(extack, "virtqueue index is not valid");
2938 		err = -EINVAL;
2939 		goto out_err;
2940 	}
2941 
2942 	if (idx == ctrl_vq_idx(mvdev)) {
2943 		cvq = &mvdev->cvq;
2944 		received_desc = cvq->received_desc;
2945 		completed_desc = cvq->completed_desc;
2946 		goto out;
2947 	}
2948 
2949 	mvq = &ndev->vqs[idx];
2950 	err = counter_set_query(ndev, mvq, &received_desc, &completed_desc);
2951 	if (err) {
2952 		NL_SET_ERR_MSG_MOD(extack, "failed to query hardware");
2953 		goto out_err;
2954 	}
2955 
2956 out:
2957 	err = -EMSGSIZE;
2958 	if (nla_put_string(msg, VDPA_ATTR_DEV_VENDOR_ATTR_NAME, "received_desc"))
2959 		goto out_err;
2960 
2961 	if (nla_put_u64_64bit(msg, VDPA_ATTR_DEV_VENDOR_ATTR_VALUE, received_desc,
2962 			      VDPA_ATTR_PAD))
2963 		goto out_err;
2964 
2965 	if (nla_put_string(msg, VDPA_ATTR_DEV_VENDOR_ATTR_NAME, "completed_desc"))
2966 		goto out_err;
2967 
2968 	if (nla_put_u64_64bit(msg, VDPA_ATTR_DEV_VENDOR_ATTR_VALUE, completed_desc,
2969 			      VDPA_ATTR_PAD))
2970 		goto out_err;
2971 
2972 	err = 0;
2973 out_err:
2974 	up_read(&ndev->reslock);
2975 	return err;
2976 }
2977 
2978 static void mlx5_vdpa_cvq_suspend(struct mlx5_vdpa_dev *mvdev)
2979 {
2980 	struct mlx5_control_vq *cvq;
2981 
2982 	if (!(mvdev->actual_features & BIT_ULL(VIRTIO_NET_F_CTRL_VQ)))
2983 		return;
2984 
2985 	cvq = &mvdev->cvq;
2986 	cvq->ready = false;
2987 }
2988 
2989 static int mlx5_vdpa_suspend(struct vdpa_device *vdev)
2990 {
2991 	struct mlx5_vdpa_dev *mvdev = to_mvdev(vdev);
2992 	struct mlx5_vdpa_net *ndev = to_mlx5_vdpa_ndev(mvdev);
2993 	struct mlx5_vdpa_virtqueue *mvq;
2994 	int i;
2995 
2996 	mlx5_vdpa_info(mvdev, "suspending device\n");
2997 
2998 	down_write(&ndev->reslock);
2999 	unregister_link_notifier(ndev);
3000 	for (i = 0; i < ndev->cur_num_vqs; i++) {
3001 		mvq = &ndev->vqs[i];
3002 		suspend_vq(ndev, mvq);
3003 	}
3004 	mlx5_vdpa_cvq_suspend(mvdev);
3005 	mvdev->suspended = true;
3006 	up_write(&ndev->reslock);
3007 	return 0;
3008 }
3009 
3010 static int mlx5_set_group_asid(struct vdpa_device *vdev, u32 group,
3011 			       unsigned int asid)
3012 {
3013 	struct mlx5_vdpa_dev *mvdev = to_mvdev(vdev);
3014 
3015 	if (group >= MLX5_VDPA_NUMVQ_GROUPS)
3016 		return -EINVAL;
3017 
3018 	mvdev->group2asid[group] = asid;
3019 	return 0;
3020 }
3021 
3022 static const struct vdpa_config_ops mlx5_vdpa_ops = {
3023 	.set_vq_address = mlx5_vdpa_set_vq_address,
3024 	.set_vq_num = mlx5_vdpa_set_vq_num,
3025 	.kick_vq = mlx5_vdpa_kick_vq,
3026 	.set_vq_cb = mlx5_vdpa_set_vq_cb,
3027 	.set_vq_ready = mlx5_vdpa_set_vq_ready,
3028 	.get_vq_ready = mlx5_vdpa_get_vq_ready,
3029 	.set_vq_state = mlx5_vdpa_set_vq_state,
3030 	.get_vq_state = mlx5_vdpa_get_vq_state,
3031 	.get_vendor_vq_stats = mlx5_vdpa_get_vendor_vq_stats,
3032 	.get_vq_notification = mlx5_get_vq_notification,
3033 	.get_vq_irq = mlx5_get_vq_irq,
3034 	.get_vq_align = mlx5_vdpa_get_vq_align,
3035 	.get_vq_group = mlx5_vdpa_get_vq_group,
3036 	.get_device_features = mlx5_vdpa_get_device_features,
3037 	.set_driver_features = mlx5_vdpa_set_driver_features,
3038 	.get_driver_features = mlx5_vdpa_get_driver_features,
3039 	.set_config_cb = mlx5_vdpa_set_config_cb,
3040 	.get_vq_num_max = mlx5_vdpa_get_vq_num_max,
3041 	.get_device_id = mlx5_vdpa_get_device_id,
3042 	.get_vendor_id = mlx5_vdpa_get_vendor_id,
3043 	.get_status = mlx5_vdpa_get_status,
3044 	.set_status = mlx5_vdpa_set_status,
3045 	.reset = mlx5_vdpa_reset,
3046 	.get_config_size = mlx5_vdpa_get_config_size,
3047 	.get_config = mlx5_vdpa_get_config,
3048 	.set_config = mlx5_vdpa_set_config,
3049 	.get_generation = mlx5_vdpa_get_generation,
3050 	.set_map = mlx5_vdpa_set_map,
3051 	.set_group_asid = mlx5_set_group_asid,
3052 	.get_vq_dma_dev = mlx5_get_vq_dma_dev,
3053 	.free = mlx5_vdpa_free,
3054 	.suspend = mlx5_vdpa_suspend,
3055 };
3056 
3057 static int query_mtu(struct mlx5_core_dev *mdev, u16 *mtu)
3058 {
3059 	u16 hw_mtu;
3060 	int err;
3061 
3062 	err = mlx5_query_nic_vport_mtu(mdev, &hw_mtu);
3063 	if (err)
3064 		return err;
3065 
3066 	*mtu = hw_mtu - MLX5V_ETH_HARD_MTU;
3067 	return 0;
3068 }
3069 
3070 static int alloc_resources(struct mlx5_vdpa_net *ndev)
3071 {
3072 	struct mlx5_vdpa_net_resources *res = &ndev->res;
3073 	int err;
3074 
3075 	if (res->valid) {
3076 		mlx5_vdpa_warn(&ndev->mvdev, "resources already allocated\n");
3077 		return -EEXIST;
3078 	}
3079 
3080 	err = mlx5_vdpa_alloc_transport_domain(&ndev->mvdev, &res->tdn);
3081 	if (err)
3082 		return err;
3083 
3084 	err = create_tis(ndev);
3085 	if (err)
3086 		goto err_tis;
3087 
3088 	res->valid = true;
3089 
3090 	return 0;
3091 
3092 err_tis:
3093 	mlx5_vdpa_dealloc_transport_domain(&ndev->mvdev, res->tdn);
3094 	return err;
3095 }
3096 
3097 static void free_resources(struct mlx5_vdpa_net *ndev)
3098 {
3099 	struct mlx5_vdpa_net_resources *res = &ndev->res;
3100 
3101 	if (!res->valid)
3102 		return;
3103 
3104 	destroy_tis(ndev);
3105 	mlx5_vdpa_dealloc_transport_domain(&ndev->mvdev, res->tdn);
3106 	res->valid = false;
3107 }
3108 
3109 static void init_mvqs(struct mlx5_vdpa_net *ndev)
3110 {
3111 	struct mlx5_vdpa_virtqueue *mvq;
3112 	int i;
3113 
3114 	for (i = 0; i < ndev->mvdev.max_vqs; ++i) {
3115 		mvq = &ndev->vqs[i];
3116 		memset(mvq, 0, offsetof(struct mlx5_vdpa_virtqueue, ri));
3117 		mvq->index = i;
3118 		mvq->ndev = ndev;
3119 		mvq->fwqp.fw = true;
3120 		mvq->fw_state = MLX5_VIRTIO_NET_Q_OBJECT_NONE;
3121 	}
3122 	for (; i < ndev->mvdev.max_vqs; i++) {
3123 		mvq = &ndev->vqs[i];
3124 		memset(mvq, 0, offsetof(struct mlx5_vdpa_virtqueue, ri));
3125 		mvq->index = i;
3126 		mvq->ndev = ndev;
3127 	}
3128 }
3129 
3130 struct mlx5_vdpa_mgmtdev {
3131 	struct vdpa_mgmt_dev mgtdev;
3132 	struct mlx5_adev *madev;
3133 	struct mlx5_vdpa_net *ndev;
3134 };
3135 
3136 static int config_func_mtu(struct mlx5_core_dev *mdev, u16 mtu)
3137 {
3138 	int inlen = MLX5_ST_SZ_BYTES(modify_nic_vport_context_in);
3139 	void *in;
3140 	int err;
3141 
3142 	in = kvzalloc(inlen, GFP_KERNEL);
3143 	if (!in)
3144 		return -ENOMEM;
3145 
3146 	MLX5_SET(modify_nic_vport_context_in, in, field_select.mtu, 1);
3147 	MLX5_SET(modify_nic_vport_context_in, in, nic_vport_context.mtu,
3148 		 mtu + MLX5V_ETH_HARD_MTU);
3149 	MLX5_SET(modify_nic_vport_context_in, in, opcode,
3150 		 MLX5_CMD_OP_MODIFY_NIC_VPORT_CONTEXT);
3151 
3152 	err = mlx5_cmd_exec_in(mdev, modify_nic_vport_context, in);
3153 
3154 	kvfree(in);
3155 	return err;
3156 }
3157 
3158 static int mlx5_vdpa_dev_add(struct vdpa_mgmt_dev *v_mdev, const char *name,
3159 			     const struct vdpa_dev_set_config *add_config)
3160 {
3161 	struct mlx5_vdpa_mgmtdev *mgtdev = container_of(v_mdev, struct mlx5_vdpa_mgmtdev, mgtdev);
3162 	struct virtio_net_config *config;
3163 	struct mlx5_core_dev *pfmdev;
3164 	struct mlx5_vdpa_dev *mvdev;
3165 	struct mlx5_vdpa_net *ndev;
3166 	struct mlx5_core_dev *mdev;
3167 	u64 device_features;
3168 	u32 max_vqs;
3169 	u16 mtu;
3170 	int err;
3171 
3172 	if (mgtdev->ndev)
3173 		return -ENOSPC;
3174 
3175 	mdev = mgtdev->madev->mdev;
3176 	device_features = mgtdev->mgtdev.supported_features;
3177 	if (add_config->mask & BIT_ULL(VDPA_ATTR_DEV_FEATURES)) {
3178 		if (add_config->device_features & ~device_features) {
3179 			dev_warn(mdev->device,
3180 				 "The provisioned features 0x%llx are not supported by this device with features 0x%llx\n",
3181 				 add_config->device_features, device_features);
3182 			return -EINVAL;
3183 		}
3184 		device_features &= add_config->device_features;
3185 	} else {
3186 		device_features &= ~BIT_ULL(VIRTIO_NET_F_MRG_RXBUF);
3187 	}
3188 	if (!(device_features & BIT_ULL(VIRTIO_F_VERSION_1) &&
3189 	      device_features & BIT_ULL(VIRTIO_F_ACCESS_PLATFORM))) {
3190 		dev_warn(mdev->device,
3191 			 "Must provision minimum features 0x%llx for this device",
3192 			 BIT_ULL(VIRTIO_F_VERSION_1) | BIT_ULL(VIRTIO_F_ACCESS_PLATFORM));
3193 		return -EOPNOTSUPP;
3194 	}
3195 
3196 	if (!(MLX5_CAP_DEV_VDPA_EMULATION(mdev, virtio_queue_type) &
3197 	    MLX5_VIRTIO_EMULATION_CAP_VIRTIO_QUEUE_TYPE_SPLIT)) {
3198 		dev_warn(mdev->device, "missing support for split virtqueues\n");
3199 		return -EOPNOTSUPP;
3200 	}
3201 
3202 	max_vqs = min_t(int, MLX5_CAP_DEV_VDPA_EMULATION(mdev, max_num_virtio_queues),
3203 			1 << MLX5_CAP_GEN(mdev, log_max_rqt_size));
3204 	if (max_vqs < 2) {
3205 		dev_warn(mdev->device,
3206 			 "%d virtqueues are supported. At least 2 are required\n",
3207 			 max_vqs);
3208 		return -EAGAIN;
3209 	}
3210 
3211 	if (add_config->mask & BIT_ULL(VDPA_ATTR_DEV_NET_CFG_MAX_VQP)) {
3212 		if (add_config->net.max_vq_pairs > max_vqs / 2)
3213 			return -EINVAL;
3214 		max_vqs = min_t(u32, max_vqs, 2 * add_config->net.max_vq_pairs);
3215 	} else {
3216 		max_vqs = 2;
3217 	}
3218 
3219 	ndev = vdpa_alloc_device(struct mlx5_vdpa_net, mvdev.vdev, mdev->device, &mlx5_vdpa_ops,
3220 				 MLX5_VDPA_NUMVQ_GROUPS, MLX5_VDPA_NUM_AS, name, false);
3221 	if (IS_ERR(ndev))
3222 		return PTR_ERR(ndev);
3223 
3224 	ndev->mvdev.max_vqs = max_vqs;
3225 	mvdev = &ndev->mvdev;
3226 	mvdev->mdev = mdev;
3227 
3228 	ndev->vqs = kcalloc(max_vqs, sizeof(*ndev->vqs), GFP_KERNEL);
3229 	ndev->event_cbs = kcalloc(max_vqs + 1, sizeof(*ndev->event_cbs), GFP_KERNEL);
3230 	if (!ndev->vqs || !ndev->event_cbs) {
3231 		err = -ENOMEM;
3232 		goto err_alloc;
3233 	}
3234 
3235 	init_mvqs(ndev);
3236 	init_rwsem(&ndev->reslock);
3237 	config = &ndev->config;
3238 
3239 	if (add_config->mask & BIT_ULL(VDPA_ATTR_DEV_NET_CFG_MTU)) {
3240 		err = config_func_mtu(mdev, add_config->net.mtu);
3241 		if (err)
3242 			goto err_alloc;
3243 	}
3244 
3245 	if (device_features & BIT_ULL(VIRTIO_NET_F_MTU)) {
3246 		err = query_mtu(mdev, &mtu);
3247 		if (err)
3248 			goto err_alloc;
3249 
3250 		ndev->config.mtu = cpu_to_mlx5vdpa16(mvdev, mtu);
3251 	}
3252 
3253 	if (device_features & BIT_ULL(VIRTIO_NET_F_STATUS)) {
3254 		if (get_link_state(mvdev))
3255 			ndev->config.status |= cpu_to_mlx5vdpa16(mvdev, VIRTIO_NET_S_LINK_UP);
3256 		else
3257 			ndev->config.status &= cpu_to_mlx5vdpa16(mvdev, ~VIRTIO_NET_S_LINK_UP);
3258 	}
3259 
3260 	if (add_config->mask & (1 << VDPA_ATTR_DEV_NET_CFG_MACADDR)) {
3261 		memcpy(ndev->config.mac, add_config->net.mac, ETH_ALEN);
3262 	/* No bother setting mac address in config if not going to provision _F_MAC */
3263 	} else if ((add_config->mask & BIT_ULL(VDPA_ATTR_DEV_FEATURES)) == 0 ||
3264 		   device_features & BIT_ULL(VIRTIO_NET_F_MAC)) {
3265 		err = mlx5_query_nic_vport_mac_address(mdev, 0, 0, config->mac);
3266 		if (err)
3267 			goto err_alloc;
3268 	}
3269 
3270 	if (!is_zero_ether_addr(config->mac)) {
3271 		pfmdev = pci_get_drvdata(pci_physfn(mdev->pdev));
3272 		err = mlx5_mpfs_add_mac(pfmdev, config->mac);
3273 		if (err)
3274 			goto err_alloc;
3275 	} else if ((add_config->mask & BIT_ULL(VDPA_ATTR_DEV_FEATURES)) == 0) {
3276 		/*
3277 		 * We used to clear _F_MAC feature bit if seeing
3278 		 * zero mac address when device features are not
3279 		 * specifically provisioned. Keep the behaviour
3280 		 * so old scripts do not break.
3281 		 */
3282 		device_features &= ~BIT_ULL(VIRTIO_NET_F_MAC);
3283 	} else if (device_features & BIT_ULL(VIRTIO_NET_F_MAC)) {
3284 		/* Don't provision zero mac address for _F_MAC */
3285 		mlx5_vdpa_warn(&ndev->mvdev,
3286 			       "No mac address provisioned?\n");
3287 		err = -EINVAL;
3288 		goto err_alloc;
3289 	}
3290 
3291 	if (device_features & BIT_ULL(VIRTIO_NET_F_MQ))
3292 		config->max_virtqueue_pairs = cpu_to_mlx5vdpa16(mvdev, max_vqs / 2);
3293 
3294 	ndev->mvdev.mlx_features = device_features;
3295 	mvdev->vdev.dma_dev = &mdev->pdev->dev;
3296 	err = mlx5_vdpa_alloc_resources(&ndev->mvdev);
3297 	if (err)
3298 		goto err_mpfs;
3299 
3300 	if (MLX5_CAP_GEN(mvdev->mdev, umem_uid_0)) {
3301 		err = mlx5_vdpa_create_mr(mvdev, NULL, 0);
3302 		if (err)
3303 			goto err_res;
3304 	}
3305 
3306 	err = alloc_resources(ndev);
3307 	if (err)
3308 		goto err_mr;
3309 
3310 	ndev->cvq_ent.mvdev = mvdev;
3311 	INIT_WORK(&ndev->cvq_ent.work, mlx5_cvq_kick_handler);
3312 	mvdev->wq = create_singlethread_workqueue("mlx5_vdpa_wq");
3313 	if (!mvdev->wq) {
3314 		err = -ENOMEM;
3315 		goto err_res2;
3316 	}
3317 
3318 	mvdev->vdev.mdev = &mgtdev->mgtdev;
3319 	err = _vdpa_register_device(&mvdev->vdev, max_vqs + 1);
3320 	if (err)
3321 		goto err_reg;
3322 
3323 	mgtdev->ndev = ndev;
3324 	return 0;
3325 
3326 err_reg:
3327 	destroy_workqueue(mvdev->wq);
3328 err_res2:
3329 	free_resources(ndev);
3330 err_mr:
3331 	mlx5_vdpa_destroy_mr(mvdev);
3332 err_res:
3333 	mlx5_vdpa_free_resources(&ndev->mvdev);
3334 err_mpfs:
3335 	if (!is_zero_ether_addr(config->mac))
3336 		mlx5_mpfs_del_mac(pfmdev, config->mac);
3337 err_alloc:
3338 	put_device(&mvdev->vdev.dev);
3339 	return err;
3340 }
3341 
3342 static void mlx5_vdpa_dev_del(struct vdpa_mgmt_dev *v_mdev, struct vdpa_device *dev)
3343 {
3344 	struct mlx5_vdpa_mgmtdev *mgtdev = container_of(v_mdev, struct mlx5_vdpa_mgmtdev, mgtdev);
3345 	struct mlx5_vdpa_dev *mvdev = to_mvdev(dev);
3346 	struct mlx5_vdpa_net *ndev = to_mlx5_vdpa_ndev(mvdev);
3347 	struct workqueue_struct *wq;
3348 
3349 	mlx5_vdpa_remove_debugfs(ndev->debugfs);
3350 	ndev->debugfs = NULL;
3351 	unregister_link_notifier(ndev);
3352 	wq = mvdev->wq;
3353 	mvdev->wq = NULL;
3354 	destroy_workqueue(wq);
3355 	_vdpa_unregister_device(dev);
3356 	mgtdev->ndev = NULL;
3357 }
3358 
3359 static const struct vdpa_mgmtdev_ops mdev_ops = {
3360 	.dev_add = mlx5_vdpa_dev_add,
3361 	.dev_del = mlx5_vdpa_dev_del,
3362 };
3363 
3364 static struct virtio_device_id id_table[] = {
3365 	{ VIRTIO_ID_NET, VIRTIO_DEV_ANY_ID },
3366 	{ 0 },
3367 };
3368 
3369 static int mlx5v_probe(struct auxiliary_device *adev,
3370 		       const struct auxiliary_device_id *id)
3371 
3372 {
3373 	struct mlx5_adev *madev = container_of(adev, struct mlx5_adev, adev);
3374 	struct mlx5_core_dev *mdev = madev->mdev;
3375 	struct mlx5_vdpa_mgmtdev *mgtdev;
3376 	int err;
3377 
3378 	mgtdev = kzalloc(sizeof(*mgtdev), GFP_KERNEL);
3379 	if (!mgtdev)
3380 		return -ENOMEM;
3381 
3382 	mgtdev->mgtdev.ops = &mdev_ops;
3383 	mgtdev->mgtdev.device = mdev->device;
3384 	mgtdev->mgtdev.id_table = id_table;
3385 	mgtdev->mgtdev.config_attr_mask = BIT_ULL(VDPA_ATTR_DEV_NET_CFG_MACADDR) |
3386 					  BIT_ULL(VDPA_ATTR_DEV_NET_CFG_MAX_VQP) |
3387 					  BIT_ULL(VDPA_ATTR_DEV_NET_CFG_MTU) |
3388 					  BIT_ULL(VDPA_ATTR_DEV_FEATURES);
3389 	mgtdev->mgtdev.max_supported_vqs =
3390 		MLX5_CAP_DEV_VDPA_EMULATION(mdev, max_num_virtio_queues) + 1;
3391 	mgtdev->mgtdev.supported_features = get_supported_features(mdev);
3392 	mgtdev->madev = madev;
3393 
3394 	err = vdpa_mgmtdev_register(&mgtdev->mgtdev);
3395 	if (err)
3396 		goto reg_err;
3397 
3398 	auxiliary_set_drvdata(adev, mgtdev);
3399 
3400 	return 0;
3401 
3402 reg_err:
3403 	kfree(mgtdev);
3404 	return err;
3405 }
3406 
3407 static void mlx5v_remove(struct auxiliary_device *adev)
3408 {
3409 	struct mlx5_vdpa_mgmtdev *mgtdev;
3410 
3411 	mgtdev = auxiliary_get_drvdata(adev);
3412 	vdpa_mgmtdev_unregister(&mgtdev->mgtdev);
3413 	kfree(mgtdev);
3414 }
3415 
3416 static const struct auxiliary_device_id mlx5v_id_table[] = {
3417 	{ .name = MLX5_ADEV_NAME ".vnet", },
3418 	{},
3419 };
3420 
3421 MODULE_DEVICE_TABLE(auxiliary, mlx5v_id_table);
3422 
3423 static struct auxiliary_driver mlx5v_driver = {
3424 	.name = "vnet",
3425 	.probe = mlx5v_probe,
3426 	.remove = mlx5v_remove,
3427 	.id_table = mlx5v_id_table,
3428 };
3429 
3430 module_auxiliary_driver(mlx5v_driver);
3431