Loading...
1// SPDX-License-Identifier: GPL-2.0-only
2/* Copyright (C) 2023 Intel Corporation */
3
4#include <net/libeth/rx.h>
5
6#include "idpf.h"
7#include "idpf_virtchnl.h"
8
9#define IDPF_VC_XN_MIN_TIMEOUT_MSEC 2000
10#define IDPF_VC_XN_DEFAULT_TIMEOUT_MSEC (60 * 1000)
11#define IDPF_VC_XN_IDX_M GENMASK(7, 0)
12#define IDPF_VC_XN_SALT_M GENMASK(15, 8)
13#define IDPF_VC_XN_RING_LEN U8_MAX
14
15/**
16 * enum idpf_vc_xn_state - Virtchnl transaction status
17 * @IDPF_VC_XN_IDLE: not expecting a reply, ready to be used
18 * @IDPF_VC_XN_WAITING: expecting a reply, not yet received
19 * @IDPF_VC_XN_COMPLETED_SUCCESS: a reply was expected and received,
20 * buffer updated
21 * @IDPF_VC_XN_COMPLETED_FAILED: a reply was expected and received, but there
22 * was an error, buffer not updated
23 * @IDPF_VC_XN_SHUTDOWN: transaction object cannot be used, VC torn down
24 * @IDPF_VC_XN_ASYNC: transaction sent asynchronously and doesn't have the
25 * return context; a callback may be provided to handle
26 * return
27 */
28enum idpf_vc_xn_state {
29 IDPF_VC_XN_IDLE = 1,
30 IDPF_VC_XN_WAITING,
31 IDPF_VC_XN_COMPLETED_SUCCESS,
32 IDPF_VC_XN_COMPLETED_FAILED,
33 IDPF_VC_XN_SHUTDOWN,
34 IDPF_VC_XN_ASYNC,
35};
36
37struct idpf_vc_xn;
38/* Callback for asynchronous messages */
39typedef int (*async_vc_cb) (struct idpf_adapter *, struct idpf_vc_xn *,
40 const struct idpf_ctlq_msg *);
41
42/**
43 * struct idpf_vc_xn - Data structure representing virtchnl transactions
44 * @completed: virtchnl event loop uses that to signal when a reply is
45 * available, uses kernel completion API
46 * @state: virtchnl event loop stores the data below, protected by the
47 * completion's lock.
48 * @reply_sz: Original size of reply, may be > reply_buf.iov_len; it will be
49 * truncated on its way to the receiver thread according to
50 * reply_buf.iov_len.
51 * @reply: Reference to the buffer(s) where the reply data should be written
52 * to. May be 0-length (then NULL address permitted) if the reply data
53 * should be ignored.
54 * @async_handler: if sent asynchronously, a callback can be provided to handle
55 * the reply when it's received
56 * @vc_op: corresponding opcode sent with this transaction
57 * @idx: index used as retrieval on reply receive, used for cookie
58 * @salt: changed every message to make unique, used for cookie
59 */
60struct idpf_vc_xn {
61 struct completion completed;
62 enum idpf_vc_xn_state state;
63 size_t reply_sz;
64 struct kvec reply;
65 async_vc_cb async_handler;
66 u32 vc_op;
67 u8 idx;
68 u8 salt;
69};
70
71/**
72 * struct idpf_vc_xn_params - Parameters for executing transaction
73 * @send_buf: kvec for send buffer
74 * @recv_buf: kvec for recv buffer, may be NULL, must then have zero length
75 * @timeout_ms: timeout to wait for reply
76 * @async: send message asynchronously, will not wait on completion
77 * @async_handler: If sent asynchronously, optional callback handler. The user
78 * must be careful when using async handlers as the memory for
79 * the recv_buf _cannot_ be on stack if this is async.
80 * @vc_op: virtchnl op to send
81 */
82struct idpf_vc_xn_params {
83 struct kvec send_buf;
84 struct kvec recv_buf;
85 int timeout_ms;
86 bool async;
87 async_vc_cb async_handler;
88 u32 vc_op;
89};
90
91/**
92 * struct idpf_vc_xn_manager - Manager for tracking transactions
93 * @ring: backing and lookup for transactions
94 * @free_xn_bm: bitmap for free transactions
95 * @xn_bm_lock: make bitmap access synchronous where necessary
96 * @salt: used to make cookie unique every message
97 */
98struct idpf_vc_xn_manager {
99 struct idpf_vc_xn ring[IDPF_VC_XN_RING_LEN];
100 DECLARE_BITMAP(free_xn_bm, IDPF_VC_XN_RING_LEN);
101 spinlock_t xn_bm_lock;
102 u8 salt;
103};
104
105/**
106 * idpf_vid_to_vport - Translate vport id to vport pointer
107 * @adapter: private data struct
108 * @v_id: vport id to translate
109 *
110 * Returns vport matching v_id, NULL if not found.
111 */
112static
113struct idpf_vport *idpf_vid_to_vport(struct idpf_adapter *adapter, u32 v_id)
114{
115 u16 num_max_vports = idpf_get_max_vports(adapter);
116 int i;
117
118 for (i = 0; i < num_max_vports; i++)
119 if (adapter->vport_ids[i] == v_id)
120 return adapter->vports[i];
121
122 return NULL;
123}
124
125/**
126 * idpf_handle_event_link - Handle link event message
127 * @adapter: private data struct
128 * @v2e: virtchnl event message
129 */
130static void idpf_handle_event_link(struct idpf_adapter *adapter,
131 const struct virtchnl2_event *v2e)
132{
133 struct idpf_netdev_priv *np;
134 struct idpf_vport *vport;
135
136 vport = idpf_vid_to_vport(adapter, le32_to_cpu(v2e->vport_id));
137 if (!vport) {
138 dev_err_ratelimited(&adapter->pdev->dev, "Failed to find vport_id %d for link event\n",
139 v2e->vport_id);
140 return;
141 }
142 np = netdev_priv(vport->netdev);
143
144 np->link_speed_mbps = le32_to_cpu(v2e->link_speed);
145
146 if (vport->link_up == v2e->link_status)
147 return;
148
149 vport->link_up = v2e->link_status;
150
151 if (np->state != __IDPF_VPORT_UP)
152 return;
153
154 if (vport->link_up) {
155 netif_tx_start_all_queues(vport->netdev);
156 netif_carrier_on(vport->netdev);
157 } else {
158 netif_tx_stop_all_queues(vport->netdev);
159 netif_carrier_off(vport->netdev);
160 }
161}
162
163/**
164 * idpf_recv_event_msg - Receive virtchnl event message
165 * @adapter: Driver specific private structure
166 * @ctlq_msg: message to copy from
167 *
168 * Receive virtchnl event message
169 */
170static void idpf_recv_event_msg(struct idpf_adapter *adapter,
171 struct idpf_ctlq_msg *ctlq_msg)
172{
173 int payload_size = ctlq_msg->ctx.indirect.payload->size;
174 struct virtchnl2_event *v2e;
175 u32 event;
176
177 if (payload_size < sizeof(*v2e)) {
178 dev_err_ratelimited(&adapter->pdev->dev, "Failed to receive valid payload for event msg (op %d len %d)\n",
179 ctlq_msg->cookie.mbx.chnl_opcode,
180 payload_size);
181 return;
182 }
183
184 v2e = (struct virtchnl2_event *)ctlq_msg->ctx.indirect.payload->va;
185 event = le32_to_cpu(v2e->event);
186
187 switch (event) {
188 case VIRTCHNL2_EVENT_LINK_CHANGE:
189 idpf_handle_event_link(adapter, v2e);
190 return;
191 default:
192 dev_err(&adapter->pdev->dev,
193 "Unknown event %d from PF\n", event);
194 break;
195 }
196}
197
198/**
199 * idpf_mb_clean - Reclaim the send mailbox queue entries
200 * @adapter: Driver specific private structure
201 *
202 * Reclaim the send mailbox queue entries to be used to send further messages
203 *
204 * Returns 0 on success, negative on failure
205 */
206static int idpf_mb_clean(struct idpf_adapter *adapter)
207{
208 u16 i, num_q_msg = IDPF_DFLT_MBX_Q_LEN;
209 struct idpf_ctlq_msg **q_msg;
210 struct idpf_dma_mem *dma_mem;
211 int err;
212
213 q_msg = kcalloc(num_q_msg, sizeof(struct idpf_ctlq_msg *), GFP_ATOMIC);
214 if (!q_msg)
215 return -ENOMEM;
216
217 err = idpf_ctlq_clean_sq(adapter->hw.asq, &num_q_msg, q_msg);
218 if (err)
219 goto err_kfree;
220
221 for (i = 0; i < num_q_msg; i++) {
222 if (!q_msg[i])
223 continue;
224 dma_mem = q_msg[i]->ctx.indirect.payload;
225 if (dma_mem)
226 dma_free_coherent(&adapter->pdev->dev, dma_mem->size,
227 dma_mem->va, dma_mem->pa);
228 kfree(q_msg[i]);
229 kfree(dma_mem);
230 }
231
232err_kfree:
233 kfree(q_msg);
234
235 return err;
236}
237
238/**
239 * idpf_send_mb_msg - Send message over mailbox
240 * @adapter: Driver specific private structure
241 * @op: virtchnl opcode
242 * @msg_size: size of the payload
243 * @msg: pointer to buffer holding the payload
244 * @cookie: unique SW generated cookie per message
245 *
246 * Will prepare the control queue message and initiates the send api
247 *
248 * Returns 0 on success, negative on failure
249 */
250int idpf_send_mb_msg(struct idpf_adapter *adapter, u32 op,
251 u16 msg_size, u8 *msg, u16 cookie)
252{
253 struct idpf_ctlq_msg *ctlq_msg;
254 struct idpf_dma_mem *dma_mem;
255 int err;
256
257 /* If we are here and a reset is detected nothing much can be
258 * done. This thread should silently abort and expected to
259 * be corrected with a new run either by user or driver
260 * flows after reset
261 */
262 if (idpf_is_reset_detected(adapter))
263 return 0;
264
265 err = idpf_mb_clean(adapter);
266 if (err)
267 return err;
268
269 ctlq_msg = kzalloc(sizeof(*ctlq_msg), GFP_ATOMIC);
270 if (!ctlq_msg)
271 return -ENOMEM;
272
273 dma_mem = kzalloc(sizeof(*dma_mem), GFP_ATOMIC);
274 if (!dma_mem) {
275 err = -ENOMEM;
276 goto dma_mem_error;
277 }
278
279 ctlq_msg->opcode = idpf_mbq_opc_send_msg_to_cp;
280 ctlq_msg->func_id = 0;
281 ctlq_msg->data_len = msg_size;
282 ctlq_msg->cookie.mbx.chnl_opcode = op;
283 ctlq_msg->cookie.mbx.chnl_retval = 0;
284 dma_mem->size = IDPF_CTLQ_MAX_BUF_LEN;
285 dma_mem->va = dma_alloc_coherent(&adapter->pdev->dev, dma_mem->size,
286 &dma_mem->pa, GFP_ATOMIC);
287 if (!dma_mem->va) {
288 err = -ENOMEM;
289 goto dma_alloc_error;
290 }
291
292 /* It's possible we're just sending an opcode but no buffer */
293 if (msg && msg_size)
294 memcpy(dma_mem->va, msg, msg_size);
295 ctlq_msg->ctx.indirect.payload = dma_mem;
296 ctlq_msg->ctx.sw_cookie.data = cookie;
297
298 err = idpf_ctlq_send(&adapter->hw, adapter->hw.asq, 1, ctlq_msg);
299 if (err)
300 goto send_error;
301
302 return 0;
303
304send_error:
305 dma_free_coherent(&adapter->pdev->dev, dma_mem->size, dma_mem->va,
306 dma_mem->pa);
307dma_alloc_error:
308 kfree(dma_mem);
309dma_mem_error:
310 kfree(ctlq_msg);
311
312 return err;
313}
314
315/* API for virtchnl "transaction" support ("xn" for short).
316 *
317 * We are reusing the completion lock to serialize the accesses to the
318 * transaction state for simplicity, but it could be its own separate synchro
319 * as well. For now, this API is only used from within a workqueue context;
320 * raw_spin_lock() is enough.
321 */
322/**
323 * idpf_vc_xn_lock - Request exclusive access to vc transaction
324 * @xn: struct idpf_vc_xn* to access
325 */
326#define idpf_vc_xn_lock(xn) \
327 raw_spin_lock(&(xn)->completed.wait.lock)
328
329/**
330 * idpf_vc_xn_unlock - Release exclusive access to vc transaction
331 * @xn: struct idpf_vc_xn* to access
332 */
333#define idpf_vc_xn_unlock(xn) \
334 raw_spin_unlock(&(xn)->completed.wait.lock)
335
336/**
337 * idpf_vc_xn_release_bufs - Release reference to reply buffer(s) and
338 * reset the transaction state.
339 * @xn: struct idpf_vc_xn to update
340 */
341static void idpf_vc_xn_release_bufs(struct idpf_vc_xn *xn)
342{
343 xn->reply.iov_base = NULL;
344 xn->reply.iov_len = 0;
345
346 if (xn->state != IDPF_VC_XN_SHUTDOWN)
347 xn->state = IDPF_VC_XN_IDLE;
348}
349
350/**
351 * idpf_vc_xn_init - Initialize virtchnl transaction object
352 * @vcxn_mngr: pointer to vc transaction manager struct
353 */
354static void idpf_vc_xn_init(struct idpf_vc_xn_manager *vcxn_mngr)
355{
356 int i;
357
358 spin_lock_init(&vcxn_mngr->xn_bm_lock);
359
360 for (i = 0; i < ARRAY_SIZE(vcxn_mngr->ring); i++) {
361 struct idpf_vc_xn *xn = &vcxn_mngr->ring[i];
362
363 xn->state = IDPF_VC_XN_IDLE;
364 xn->idx = i;
365 idpf_vc_xn_release_bufs(xn);
366 init_completion(&xn->completed);
367 }
368
369 bitmap_fill(vcxn_mngr->free_xn_bm, IDPF_VC_XN_RING_LEN);
370}
371
372/**
373 * idpf_vc_xn_shutdown - Uninitialize virtchnl transaction object
374 * @vcxn_mngr: pointer to vc transaction manager struct
375 *
376 * All waiting threads will be woken-up and their transaction aborted. Further
377 * operations on that object will fail.
378 */
379static void idpf_vc_xn_shutdown(struct idpf_vc_xn_manager *vcxn_mngr)
380{
381 int i;
382
383 spin_lock_bh(&vcxn_mngr->xn_bm_lock);
384 bitmap_zero(vcxn_mngr->free_xn_bm, IDPF_VC_XN_RING_LEN);
385 spin_unlock_bh(&vcxn_mngr->xn_bm_lock);
386
387 for (i = 0; i < ARRAY_SIZE(vcxn_mngr->ring); i++) {
388 struct idpf_vc_xn *xn = &vcxn_mngr->ring[i];
389
390 idpf_vc_xn_lock(xn);
391 xn->state = IDPF_VC_XN_SHUTDOWN;
392 idpf_vc_xn_release_bufs(xn);
393 idpf_vc_xn_unlock(xn);
394 complete_all(&xn->completed);
395 }
396}
397
398/**
399 * idpf_vc_xn_pop_free - Pop a free transaction from free list
400 * @vcxn_mngr: transaction manager to pop from
401 *
402 * Returns NULL if no free transactions
403 */
404static
405struct idpf_vc_xn *idpf_vc_xn_pop_free(struct idpf_vc_xn_manager *vcxn_mngr)
406{
407 struct idpf_vc_xn *xn = NULL;
408 unsigned long free_idx;
409
410 spin_lock_bh(&vcxn_mngr->xn_bm_lock);
411 free_idx = find_first_bit(vcxn_mngr->free_xn_bm, IDPF_VC_XN_RING_LEN);
412 if (free_idx == IDPF_VC_XN_RING_LEN)
413 goto do_unlock;
414
415 clear_bit(free_idx, vcxn_mngr->free_xn_bm);
416 xn = &vcxn_mngr->ring[free_idx];
417 xn->salt = vcxn_mngr->salt++;
418
419do_unlock:
420 spin_unlock_bh(&vcxn_mngr->xn_bm_lock);
421
422 return xn;
423}
424
425/**
426 * idpf_vc_xn_push_free - Push a free transaction to free list
427 * @vcxn_mngr: transaction manager to push to
428 * @xn: transaction to push
429 */
430static void idpf_vc_xn_push_free(struct idpf_vc_xn_manager *vcxn_mngr,
431 struct idpf_vc_xn *xn)
432{
433 idpf_vc_xn_release_bufs(xn);
434 set_bit(xn->idx, vcxn_mngr->free_xn_bm);
435}
436
437/**
438 * idpf_vc_xn_exec - Perform a send/recv virtchnl transaction
439 * @adapter: driver specific private structure with vcxn_mngr
440 * @params: parameters for this particular transaction including
441 * -vc_op: virtchannel operation to send
442 * -send_buf: kvec iov for send buf and len
443 * -recv_buf: kvec iov for recv buf and len (ignored if NULL)
444 * -timeout_ms: timeout waiting for a reply (milliseconds)
445 * -async: don't wait for message reply, will lose caller context
446 * -async_handler: callback to handle async replies
447 *
448 * @returns >= 0 for success, the size of the initial reply (may or may not be
449 * >= @recv_buf.iov_len, but we never overflow @@recv_buf_iov_base). < 0 for
450 * error.
451 */
452static ssize_t idpf_vc_xn_exec(struct idpf_adapter *adapter,
453 const struct idpf_vc_xn_params *params)
454{
455 const struct kvec *send_buf = ¶ms->send_buf;
456 struct idpf_vc_xn *xn;
457 ssize_t retval;
458 u16 cookie;
459
460 xn = idpf_vc_xn_pop_free(adapter->vcxn_mngr);
461 /* no free transactions available */
462 if (!xn)
463 return -ENOSPC;
464
465 idpf_vc_xn_lock(xn);
466 if (xn->state == IDPF_VC_XN_SHUTDOWN) {
467 retval = -ENXIO;
468 goto only_unlock;
469 } else if (xn->state != IDPF_VC_XN_IDLE) {
470 /* We're just going to clobber this transaction even though
471 * it's not IDLE. If we don't reuse it we could theoretically
472 * eventually leak all the free transactions and not be able to
473 * send any messages. At least this way we make an attempt to
474 * remain functional even though something really bad is
475 * happening that's corrupting what was supposed to be free
476 * transactions.
477 */
478 WARN_ONCE(1, "There should only be idle transactions in free list (idx %d op %d)\n",
479 xn->idx, xn->vc_op);
480 }
481
482 xn->reply = params->recv_buf;
483 xn->reply_sz = 0;
484 xn->state = params->async ? IDPF_VC_XN_ASYNC : IDPF_VC_XN_WAITING;
485 xn->vc_op = params->vc_op;
486 xn->async_handler = params->async_handler;
487 idpf_vc_xn_unlock(xn);
488
489 if (!params->async)
490 reinit_completion(&xn->completed);
491 cookie = FIELD_PREP(IDPF_VC_XN_SALT_M, xn->salt) |
492 FIELD_PREP(IDPF_VC_XN_IDX_M, xn->idx);
493
494 retval = idpf_send_mb_msg(adapter, params->vc_op,
495 send_buf->iov_len, send_buf->iov_base,
496 cookie);
497 if (retval) {
498 idpf_vc_xn_lock(xn);
499 goto release_and_unlock;
500 }
501
502 if (params->async)
503 return 0;
504
505 wait_for_completion_timeout(&xn->completed,
506 msecs_to_jiffies(params->timeout_ms));
507
508 /* No need to check the return value; we check the final state of the
509 * transaction below. It's possible the transaction actually gets more
510 * timeout than specified if we get preempted here but after
511 * wait_for_completion_timeout returns. This should be non-issue
512 * however.
513 */
514 idpf_vc_xn_lock(xn);
515 switch (xn->state) {
516 case IDPF_VC_XN_SHUTDOWN:
517 retval = -ENXIO;
518 goto only_unlock;
519 case IDPF_VC_XN_WAITING:
520 dev_notice_ratelimited(&adapter->pdev->dev, "Transaction timed-out (op %d, %dms)\n",
521 params->vc_op, params->timeout_ms);
522 retval = -ETIME;
523 break;
524 case IDPF_VC_XN_COMPLETED_SUCCESS:
525 retval = xn->reply_sz;
526 break;
527 case IDPF_VC_XN_COMPLETED_FAILED:
528 dev_notice_ratelimited(&adapter->pdev->dev, "Transaction failed (op %d)\n",
529 params->vc_op);
530 retval = -EIO;
531 break;
532 default:
533 /* Invalid state. */
534 WARN_ON_ONCE(1);
535 retval = -EIO;
536 break;
537 }
538
539release_and_unlock:
540 idpf_vc_xn_push_free(adapter->vcxn_mngr, xn);
541 /* If we receive a VC reply after here, it will be dropped. */
542only_unlock:
543 idpf_vc_xn_unlock(xn);
544
545 return retval;
546}
547
548/**
549 * idpf_vc_xn_forward_async - Handle async reply receives
550 * @adapter: private data struct
551 * @xn: transaction to handle
552 * @ctlq_msg: corresponding ctlq_msg
553 *
554 * For async sends we're going to lose the caller's context so, if an
555 * async_handler was provided, it can deal with the reply, otherwise we'll just
556 * check and report if there is an error.
557 */
558static int
559idpf_vc_xn_forward_async(struct idpf_adapter *adapter, struct idpf_vc_xn *xn,
560 const struct idpf_ctlq_msg *ctlq_msg)
561{
562 int err = 0;
563
564 if (ctlq_msg->cookie.mbx.chnl_opcode != xn->vc_op) {
565 dev_err_ratelimited(&adapter->pdev->dev, "Async message opcode does not match transaction opcode (msg: %d) (xn: %d)\n",
566 ctlq_msg->cookie.mbx.chnl_opcode, xn->vc_op);
567 xn->reply_sz = 0;
568 err = -EINVAL;
569 goto release_bufs;
570 }
571
572 if (xn->async_handler) {
573 err = xn->async_handler(adapter, xn, ctlq_msg);
574 goto release_bufs;
575 }
576
577 if (ctlq_msg->cookie.mbx.chnl_retval) {
578 xn->reply_sz = 0;
579 dev_err_ratelimited(&adapter->pdev->dev, "Async message failure (op %d)\n",
580 ctlq_msg->cookie.mbx.chnl_opcode);
581 err = -EINVAL;
582 }
583
584release_bufs:
585 idpf_vc_xn_push_free(adapter->vcxn_mngr, xn);
586
587 return err;
588}
589
590/**
591 * idpf_vc_xn_forward_reply - copy a reply back to receiving thread
592 * @adapter: driver specific private structure with vcxn_mngr
593 * @ctlq_msg: controlq message to send back to receiving thread
594 */
595static int
596idpf_vc_xn_forward_reply(struct idpf_adapter *adapter,
597 const struct idpf_ctlq_msg *ctlq_msg)
598{
599 const void *payload = NULL;
600 size_t payload_size = 0;
601 struct idpf_vc_xn *xn;
602 u16 msg_info;
603 int err = 0;
604 u16 xn_idx;
605 u16 salt;
606
607 msg_info = ctlq_msg->ctx.sw_cookie.data;
608 xn_idx = FIELD_GET(IDPF_VC_XN_IDX_M, msg_info);
609 if (xn_idx >= ARRAY_SIZE(adapter->vcxn_mngr->ring)) {
610 dev_err_ratelimited(&adapter->pdev->dev, "Out of bounds cookie received: %02x\n",
611 xn_idx);
612 return -EINVAL;
613 }
614 xn = &adapter->vcxn_mngr->ring[xn_idx];
615 idpf_vc_xn_lock(xn);
616 salt = FIELD_GET(IDPF_VC_XN_SALT_M, msg_info);
617 if (xn->salt != salt) {
618 dev_err_ratelimited(&adapter->pdev->dev, "Transaction salt does not match (%02x != %02x)\n",
619 xn->salt, salt);
620 idpf_vc_xn_unlock(xn);
621 return -EINVAL;
622 }
623
624 switch (xn->state) {
625 case IDPF_VC_XN_WAITING:
626 /* success */
627 break;
628 case IDPF_VC_XN_IDLE:
629 dev_err_ratelimited(&adapter->pdev->dev, "Unexpected or belated VC reply (op %d)\n",
630 ctlq_msg->cookie.mbx.chnl_opcode);
631 err = -EINVAL;
632 goto out_unlock;
633 case IDPF_VC_XN_SHUTDOWN:
634 /* ENXIO is a bit special here as the recv msg loop uses that
635 * know if it should stop trying to clean the ring if we lost
636 * the virtchnl. We need to stop playing with registers and
637 * yield.
638 */
639 err = -ENXIO;
640 goto out_unlock;
641 case IDPF_VC_XN_ASYNC:
642 err = idpf_vc_xn_forward_async(adapter, xn, ctlq_msg);
643 idpf_vc_xn_unlock(xn);
644 return err;
645 default:
646 dev_err_ratelimited(&adapter->pdev->dev, "Overwriting VC reply (op %d)\n",
647 ctlq_msg->cookie.mbx.chnl_opcode);
648 err = -EBUSY;
649 goto out_unlock;
650 }
651
652 if (ctlq_msg->cookie.mbx.chnl_opcode != xn->vc_op) {
653 dev_err_ratelimited(&adapter->pdev->dev, "Message opcode does not match transaction opcode (msg: %d) (xn: %d)\n",
654 ctlq_msg->cookie.mbx.chnl_opcode, xn->vc_op);
655 xn->reply_sz = 0;
656 xn->state = IDPF_VC_XN_COMPLETED_FAILED;
657 err = -EINVAL;
658 goto out_unlock;
659 }
660
661 if (ctlq_msg->cookie.mbx.chnl_retval) {
662 xn->reply_sz = 0;
663 xn->state = IDPF_VC_XN_COMPLETED_FAILED;
664 err = -EINVAL;
665 goto out_unlock;
666 }
667
668 if (ctlq_msg->data_len) {
669 payload = ctlq_msg->ctx.indirect.payload->va;
670 payload_size = ctlq_msg->data_len;
671 }
672
673 xn->reply_sz = payload_size;
674 xn->state = IDPF_VC_XN_COMPLETED_SUCCESS;
675
676 if (xn->reply.iov_base && xn->reply.iov_len && payload_size)
677 memcpy(xn->reply.iov_base, payload,
678 min_t(size_t, xn->reply.iov_len, payload_size));
679
680out_unlock:
681 idpf_vc_xn_unlock(xn);
682 /* we _cannot_ hold lock while calling complete */
683 complete(&xn->completed);
684
685 return err;
686}
687
688/**
689 * idpf_recv_mb_msg - Receive message over mailbox
690 * @adapter: Driver specific private structure
691 *
692 * Will receive control queue message and posts the receive buffer. Returns 0
693 * on success and negative on failure.
694 */
695int idpf_recv_mb_msg(struct idpf_adapter *adapter)
696{
697 struct idpf_ctlq_msg ctlq_msg;
698 struct idpf_dma_mem *dma_mem;
699 int post_err, err;
700 u16 num_recv;
701
702 while (1) {
703 /* This will get <= num_recv messages and output how many
704 * actually received on num_recv.
705 */
706 num_recv = 1;
707 err = idpf_ctlq_recv(adapter->hw.arq, &num_recv, &ctlq_msg);
708 if (err || !num_recv)
709 break;
710
711 if (ctlq_msg.data_len) {
712 dma_mem = ctlq_msg.ctx.indirect.payload;
713 } else {
714 dma_mem = NULL;
715 num_recv = 0;
716 }
717
718 if (ctlq_msg.cookie.mbx.chnl_opcode == VIRTCHNL2_OP_EVENT)
719 idpf_recv_event_msg(adapter, &ctlq_msg);
720 else
721 err = idpf_vc_xn_forward_reply(adapter, &ctlq_msg);
722
723 post_err = idpf_ctlq_post_rx_buffs(&adapter->hw,
724 adapter->hw.arq,
725 &num_recv, &dma_mem);
726
727 /* If post failed clear the only buffer we supplied */
728 if (post_err) {
729 if (dma_mem)
730 dmam_free_coherent(&adapter->pdev->dev,
731 dma_mem->size, dma_mem->va,
732 dma_mem->pa);
733 break;
734 }
735
736 /* virtchnl trying to shutdown, stop cleaning */
737 if (err == -ENXIO)
738 break;
739 }
740
741 return err;
742}
743
744/**
745 * idpf_wait_for_marker_event - wait for software marker response
746 * @vport: virtual port data structure
747 *
748 * Returns 0 success, negative on failure.
749 **/
750static int idpf_wait_for_marker_event(struct idpf_vport *vport)
751{
752 int event;
753 int i;
754
755 for (i = 0; i < vport->num_txq; i++)
756 idpf_queue_set(SW_MARKER, vport->txqs[i]);
757
758 event = wait_event_timeout(vport->sw_marker_wq,
759 test_and_clear_bit(IDPF_VPORT_SW_MARKER,
760 vport->flags),
761 msecs_to_jiffies(500));
762
763 for (i = 0; i < vport->num_txq; i++)
764 idpf_queue_clear(POLL_MODE, vport->txqs[i]);
765
766 if (event)
767 return 0;
768
769 dev_warn(&vport->adapter->pdev->dev, "Failed to receive marker packets\n");
770
771 return -ETIMEDOUT;
772}
773
774/**
775 * idpf_send_ver_msg - send virtchnl version message
776 * @adapter: Driver specific private structure
777 *
778 * Send virtchnl version message. Returns 0 on success, negative on failure.
779 */
780static int idpf_send_ver_msg(struct idpf_adapter *adapter)
781{
782 struct idpf_vc_xn_params xn_params = {};
783 struct virtchnl2_version_info vvi;
784 ssize_t reply_sz;
785 u32 major, minor;
786 int err = 0;
787
788 if (adapter->virt_ver_maj) {
789 vvi.major = cpu_to_le32(adapter->virt_ver_maj);
790 vvi.minor = cpu_to_le32(adapter->virt_ver_min);
791 } else {
792 vvi.major = cpu_to_le32(IDPF_VIRTCHNL_VERSION_MAJOR);
793 vvi.minor = cpu_to_le32(IDPF_VIRTCHNL_VERSION_MINOR);
794 }
795
796 xn_params.vc_op = VIRTCHNL2_OP_VERSION;
797 xn_params.send_buf.iov_base = &vvi;
798 xn_params.send_buf.iov_len = sizeof(vvi);
799 xn_params.recv_buf = xn_params.send_buf;
800 xn_params.timeout_ms = IDPF_VC_XN_DEFAULT_TIMEOUT_MSEC;
801
802 reply_sz = idpf_vc_xn_exec(adapter, &xn_params);
803 if (reply_sz < 0)
804 return reply_sz;
805 if (reply_sz < sizeof(vvi))
806 return -EIO;
807
808 major = le32_to_cpu(vvi.major);
809 minor = le32_to_cpu(vvi.minor);
810
811 if (major > IDPF_VIRTCHNL_VERSION_MAJOR) {
812 dev_warn(&adapter->pdev->dev, "Virtchnl major version greater than supported\n");
813 return -EINVAL;
814 }
815
816 if (major == IDPF_VIRTCHNL_VERSION_MAJOR &&
817 minor > IDPF_VIRTCHNL_VERSION_MINOR)
818 dev_warn(&adapter->pdev->dev, "Virtchnl minor version didn't match\n");
819
820 /* If we have a mismatch, resend version to update receiver on what
821 * version we will use.
822 */
823 if (!adapter->virt_ver_maj &&
824 major != IDPF_VIRTCHNL_VERSION_MAJOR &&
825 minor != IDPF_VIRTCHNL_VERSION_MINOR)
826 err = -EAGAIN;
827
828 adapter->virt_ver_maj = major;
829 adapter->virt_ver_min = minor;
830
831 return err;
832}
833
834/**
835 * idpf_send_get_caps_msg - Send virtchnl get capabilities message
836 * @adapter: Driver specific private structure
837 *
838 * Send virtchl get capabilities message. Returns 0 on success, negative on
839 * failure.
840 */
841static int idpf_send_get_caps_msg(struct idpf_adapter *adapter)
842{
843 struct virtchnl2_get_capabilities caps = {};
844 struct idpf_vc_xn_params xn_params = {};
845 ssize_t reply_sz;
846
847 caps.csum_caps =
848 cpu_to_le32(VIRTCHNL2_CAP_TX_CSUM_L3_IPV4 |
849 VIRTCHNL2_CAP_TX_CSUM_L4_IPV4_TCP |
850 VIRTCHNL2_CAP_TX_CSUM_L4_IPV4_UDP |
851 VIRTCHNL2_CAP_TX_CSUM_L4_IPV4_SCTP |
852 VIRTCHNL2_CAP_TX_CSUM_L4_IPV6_TCP |
853 VIRTCHNL2_CAP_TX_CSUM_L4_IPV6_UDP |
854 VIRTCHNL2_CAP_TX_CSUM_L4_IPV6_SCTP |
855 VIRTCHNL2_CAP_RX_CSUM_L3_IPV4 |
856 VIRTCHNL2_CAP_RX_CSUM_L4_IPV4_TCP |
857 VIRTCHNL2_CAP_RX_CSUM_L4_IPV4_UDP |
858 VIRTCHNL2_CAP_RX_CSUM_L4_IPV4_SCTP |
859 VIRTCHNL2_CAP_RX_CSUM_L4_IPV6_TCP |
860 VIRTCHNL2_CAP_RX_CSUM_L4_IPV6_UDP |
861 VIRTCHNL2_CAP_RX_CSUM_L4_IPV6_SCTP |
862 VIRTCHNL2_CAP_TX_CSUM_L3_SINGLE_TUNNEL |
863 VIRTCHNL2_CAP_RX_CSUM_L3_SINGLE_TUNNEL |
864 VIRTCHNL2_CAP_TX_CSUM_L4_SINGLE_TUNNEL |
865 VIRTCHNL2_CAP_RX_CSUM_L4_SINGLE_TUNNEL |
866 VIRTCHNL2_CAP_RX_CSUM_GENERIC);
867
868 caps.seg_caps =
869 cpu_to_le32(VIRTCHNL2_CAP_SEG_IPV4_TCP |
870 VIRTCHNL2_CAP_SEG_IPV4_UDP |
871 VIRTCHNL2_CAP_SEG_IPV4_SCTP |
872 VIRTCHNL2_CAP_SEG_IPV6_TCP |
873 VIRTCHNL2_CAP_SEG_IPV6_UDP |
874 VIRTCHNL2_CAP_SEG_IPV6_SCTP |
875 VIRTCHNL2_CAP_SEG_TX_SINGLE_TUNNEL);
876
877 caps.rss_caps =
878 cpu_to_le64(VIRTCHNL2_CAP_RSS_IPV4_TCP |
879 VIRTCHNL2_CAP_RSS_IPV4_UDP |
880 VIRTCHNL2_CAP_RSS_IPV4_SCTP |
881 VIRTCHNL2_CAP_RSS_IPV4_OTHER |
882 VIRTCHNL2_CAP_RSS_IPV6_TCP |
883 VIRTCHNL2_CAP_RSS_IPV6_UDP |
884 VIRTCHNL2_CAP_RSS_IPV6_SCTP |
885 VIRTCHNL2_CAP_RSS_IPV6_OTHER);
886
887 caps.hsplit_caps =
888 cpu_to_le32(VIRTCHNL2_CAP_RX_HSPLIT_AT_L4V4 |
889 VIRTCHNL2_CAP_RX_HSPLIT_AT_L4V6);
890
891 caps.rsc_caps =
892 cpu_to_le32(VIRTCHNL2_CAP_RSC_IPV4_TCP |
893 VIRTCHNL2_CAP_RSC_IPV6_TCP);
894
895 caps.other_caps =
896 cpu_to_le64(VIRTCHNL2_CAP_SRIOV |
897 VIRTCHNL2_CAP_MACFILTER |
898 VIRTCHNL2_CAP_SPLITQ_QSCHED |
899 VIRTCHNL2_CAP_PROMISC |
900 VIRTCHNL2_CAP_LOOPBACK);
901
902 xn_params.vc_op = VIRTCHNL2_OP_GET_CAPS;
903 xn_params.send_buf.iov_base = ∩︀
904 xn_params.send_buf.iov_len = sizeof(caps);
905 xn_params.recv_buf.iov_base = &adapter->caps;
906 xn_params.recv_buf.iov_len = sizeof(adapter->caps);
907 xn_params.timeout_ms = IDPF_VC_XN_DEFAULT_TIMEOUT_MSEC;
908
909 reply_sz = idpf_vc_xn_exec(adapter, &xn_params);
910 if (reply_sz < 0)
911 return reply_sz;
912 if (reply_sz < sizeof(adapter->caps))
913 return -EIO;
914
915 return 0;
916}
917
918/**
919 * idpf_vport_alloc_max_qs - Allocate max queues for a vport
920 * @adapter: Driver specific private structure
921 * @max_q: vport max queue structure
922 */
923int idpf_vport_alloc_max_qs(struct idpf_adapter *adapter,
924 struct idpf_vport_max_q *max_q)
925{
926 struct idpf_avail_queue_info *avail_queues = &adapter->avail_queues;
927 struct virtchnl2_get_capabilities *caps = &adapter->caps;
928 u16 default_vports = idpf_get_default_vports(adapter);
929 int max_rx_q, max_tx_q;
930
931 mutex_lock(&adapter->queue_lock);
932
933 max_rx_q = le16_to_cpu(caps->max_rx_q) / default_vports;
934 max_tx_q = le16_to_cpu(caps->max_tx_q) / default_vports;
935 if (adapter->num_alloc_vports < default_vports) {
936 max_q->max_rxq = min_t(u16, max_rx_q, IDPF_MAX_Q);
937 max_q->max_txq = min_t(u16, max_tx_q, IDPF_MAX_Q);
938 } else {
939 max_q->max_rxq = IDPF_MIN_Q;
940 max_q->max_txq = IDPF_MIN_Q;
941 }
942 max_q->max_bufq = max_q->max_rxq * IDPF_MAX_BUFQS_PER_RXQ_GRP;
943 max_q->max_complq = max_q->max_txq;
944
945 if (avail_queues->avail_rxq < max_q->max_rxq ||
946 avail_queues->avail_txq < max_q->max_txq ||
947 avail_queues->avail_bufq < max_q->max_bufq ||
948 avail_queues->avail_complq < max_q->max_complq) {
949 mutex_unlock(&adapter->queue_lock);
950
951 return -EINVAL;
952 }
953
954 avail_queues->avail_rxq -= max_q->max_rxq;
955 avail_queues->avail_txq -= max_q->max_txq;
956 avail_queues->avail_bufq -= max_q->max_bufq;
957 avail_queues->avail_complq -= max_q->max_complq;
958
959 mutex_unlock(&adapter->queue_lock);
960
961 return 0;
962}
963
964/**
965 * idpf_vport_dealloc_max_qs - Deallocate max queues of a vport
966 * @adapter: Driver specific private structure
967 * @max_q: vport max queue structure
968 */
969void idpf_vport_dealloc_max_qs(struct idpf_adapter *adapter,
970 struct idpf_vport_max_q *max_q)
971{
972 struct idpf_avail_queue_info *avail_queues;
973
974 mutex_lock(&adapter->queue_lock);
975 avail_queues = &adapter->avail_queues;
976
977 avail_queues->avail_rxq += max_q->max_rxq;
978 avail_queues->avail_txq += max_q->max_txq;
979 avail_queues->avail_bufq += max_q->max_bufq;
980 avail_queues->avail_complq += max_q->max_complq;
981
982 mutex_unlock(&adapter->queue_lock);
983}
984
985/**
986 * idpf_init_avail_queues - Initialize available queues on the device
987 * @adapter: Driver specific private structure
988 */
989static void idpf_init_avail_queues(struct idpf_adapter *adapter)
990{
991 struct idpf_avail_queue_info *avail_queues = &adapter->avail_queues;
992 struct virtchnl2_get_capabilities *caps = &adapter->caps;
993
994 avail_queues->avail_rxq = le16_to_cpu(caps->max_rx_q);
995 avail_queues->avail_txq = le16_to_cpu(caps->max_tx_q);
996 avail_queues->avail_bufq = le16_to_cpu(caps->max_rx_bufq);
997 avail_queues->avail_complq = le16_to_cpu(caps->max_tx_complq);
998}
999
1000/**
1001 * idpf_get_reg_intr_vecs - Get vector queue register offset
1002 * @vport: virtual port structure
1003 * @reg_vals: Register offsets to store in
1004 *
1005 * Returns number of registers that got populated
1006 */
1007int idpf_get_reg_intr_vecs(struct idpf_vport *vport,
1008 struct idpf_vec_regs *reg_vals)
1009{
1010 struct virtchnl2_vector_chunks *chunks;
1011 struct idpf_vec_regs reg_val;
1012 u16 num_vchunks, num_vec;
1013 int num_regs = 0, i, j;
1014
1015 chunks = &vport->adapter->req_vec_chunks->vchunks;
1016 num_vchunks = le16_to_cpu(chunks->num_vchunks);
1017
1018 for (j = 0; j < num_vchunks; j++) {
1019 struct virtchnl2_vector_chunk *chunk;
1020 u32 dynctl_reg_spacing;
1021 u32 itrn_reg_spacing;
1022
1023 chunk = &chunks->vchunks[j];
1024 num_vec = le16_to_cpu(chunk->num_vectors);
1025 reg_val.dyn_ctl_reg = le32_to_cpu(chunk->dynctl_reg_start);
1026 reg_val.itrn_reg = le32_to_cpu(chunk->itrn_reg_start);
1027 reg_val.itrn_index_spacing = le32_to_cpu(chunk->itrn_index_spacing);
1028
1029 dynctl_reg_spacing = le32_to_cpu(chunk->dynctl_reg_spacing);
1030 itrn_reg_spacing = le32_to_cpu(chunk->itrn_reg_spacing);
1031
1032 for (i = 0; i < num_vec; i++) {
1033 reg_vals[num_regs].dyn_ctl_reg = reg_val.dyn_ctl_reg;
1034 reg_vals[num_regs].itrn_reg = reg_val.itrn_reg;
1035 reg_vals[num_regs].itrn_index_spacing =
1036 reg_val.itrn_index_spacing;
1037
1038 reg_val.dyn_ctl_reg += dynctl_reg_spacing;
1039 reg_val.itrn_reg += itrn_reg_spacing;
1040 num_regs++;
1041 }
1042 }
1043
1044 return num_regs;
1045}
1046
1047/**
1048 * idpf_vport_get_q_reg - Get the queue registers for the vport
1049 * @reg_vals: register values needing to be set
1050 * @num_regs: amount we expect to fill
1051 * @q_type: queue model
1052 * @chunks: queue regs received over mailbox
1053 *
1054 * This function parses the queue register offsets from the queue register
1055 * chunk information, with a specific queue type and stores it into the array
1056 * passed as an argument. It returns the actual number of queue registers that
1057 * are filled.
1058 */
1059static int idpf_vport_get_q_reg(u32 *reg_vals, int num_regs, u32 q_type,
1060 struct virtchnl2_queue_reg_chunks *chunks)
1061{
1062 u16 num_chunks = le16_to_cpu(chunks->num_chunks);
1063 int reg_filled = 0, i;
1064 u32 reg_val;
1065
1066 while (num_chunks--) {
1067 struct virtchnl2_queue_reg_chunk *chunk;
1068 u16 num_q;
1069
1070 chunk = &chunks->chunks[num_chunks];
1071 if (le32_to_cpu(chunk->type) != q_type)
1072 continue;
1073
1074 num_q = le32_to_cpu(chunk->num_queues);
1075 reg_val = le64_to_cpu(chunk->qtail_reg_start);
1076 for (i = 0; i < num_q && reg_filled < num_regs ; i++) {
1077 reg_vals[reg_filled++] = reg_val;
1078 reg_val += le32_to_cpu(chunk->qtail_reg_spacing);
1079 }
1080 }
1081
1082 return reg_filled;
1083}
1084
1085/**
1086 * __idpf_queue_reg_init - initialize queue registers
1087 * @vport: virtual port structure
1088 * @reg_vals: registers we are initializing
1089 * @num_regs: how many registers there are in total
1090 * @q_type: queue model
1091 *
1092 * Return number of queues that are initialized
1093 */
1094static int __idpf_queue_reg_init(struct idpf_vport *vport, u32 *reg_vals,
1095 int num_regs, u32 q_type)
1096{
1097 struct idpf_adapter *adapter = vport->adapter;
1098 int i, j, k = 0;
1099
1100 switch (q_type) {
1101 case VIRTCHNL2_QUEUE_TYPE_TX:
1102 for (i = 0; i < vport->num_txq_grp; i++) {
1103 struct idpf_txq_group *tx_qgrp = &vport->txq_grps[i];
1104
1105 for (j = 0; j < tx_qgrp->num_txq && k < num_regs; j++, k++)
1106 tx_qgrp->txqs[j]->tail =
1107 idpf_get_reg_addr(adapter, reg_vals[k]);
1108 }
1109 break;
1110 case VIRTCHNL2_QUEUE_TYPE_RX:
1111 for (i = 0; i < vport->num_rxq_grp; i++) {
1112 struct idpf_rxq_group *rx_qgrp = &vport->rxq_grps[i];
1113 u16 num_rxq = rx_qgrp->singleq.num_rxq;
1114
1115 for (j = 0; j < num_rxq && k < num_regs; j++, k++) {
1116 struct idpf_rx_queue *q;
1117
1118 q = rx_qgrp->singleq.rxqs[j];
1119 q->tail = idpf_get_reg_addr(adapter,
1120 reg_vals[k]);
1121 }
1122 }
1123 break;
1124 case VIRTCHNL2_QUEUE_TYPE_RX_BUFFER:
1125 for (i = 0; i < vport->num_rxq_grp; i++) {
1126 struct idpf_rxq_group *rx_qgrp = &vport->rxq_grps[i];
1127 u8 num_bufqs = vport->num_bufqs_per_qgrp;
1128
1129 for (j = 0; j < num_bufqs && k < num_regs; j++, k++) {
1130 struct idpf_buf_queue *q;
1131
1132 q = &rx_qgrp->splitq.bufq_sets[j].bufq;
1133 q->tail = idpf_get_reg_addr(adapter,
1134 reg_vals[k]);
1135 }
1136 }
1137 break;
1138 default:
1139 break;
1140 }
1141
1142 return k;
1143}
1144
1145/**
1146 * idpf_queue_reg_init - initialize queue registers
1147 * @vport: virtual port structure
1148 *
1149 * Return 0 on success, negative on failure
1150 */
1151int idpf_queue_reg_init(struct idpf_vport *vport)
1152{
1153 struct virtchnl2_create_vport *vport_params;
1154 struct virtchnl2_queue_reg_chunks *chunks;
1155 struct idpf_vport_config *vport_config;
1156 u16 vport_idx = vport->idx;
1157 int num_regs, ret = 0;
1158 u32 *reg_vals;
1159
1160 /* We may never deal with more than 256 same type of queues */
1161 reg_vals = kzalloc(sizeof(void *) * IDPF_LARGE_MAX_Q, GFP_KERNEL);
1162 if (!reg_vals)
1163 return -ENOMEM;
1164
1165 vport_config = vport->adapter->vport_config[vport_idx];
1166 if (vport_config->req_qs_chunks) {
1167 struct virtchnl2_add_queues *vc_aq =
1168 (struct virtchnl2_add_queues *)vport_config->req_qs_chunks;
1169 chunks = &vc_aq->chunks;
1170 } else {
1171 vport_params = vport->adapter->vport_params_recvd[vport_idx];
1172 chunks = &vport_params->chunks;
1173 }
1174
1175 /* Initialize Tx queue tail register address */
1176 num_regs = idpf_vport_get_q_reg(reg_vals, IDPF_LARGE_MAX_Q,
1177 VIRTCHNL2_QUEUE_TYPE_TX,
1178 chunks);
1179 if (num_regs < vport->num_txq) {
1180 ret = -EINVAL;
1181 goto free_reg_vals;
1182 }
1183
1184 num_regs = __idpf_queue_reg_init(vport, reg_vals, num_regs,
1185 VIRTCHNL2_QUEUE_TYPE_TX);
1186 if (num_regs < vport->num_txq) {
1187 ret = -EINVAL;
1188 goto free_reg_vals;
1189 }
1190
1191 /* Initialize Rx/buffer queue tail register address based on Rx queue
1192 * model
1193 */
1194 if (idpf_is_queue_model_split(vport->rxq_model)) {
1195 num_regs = idpf_vport_get_q_reg(reg_vals, IDPF_LARGE_MAX_Q,
1196 VIRTCHNL2_QUEUE_TYPE_RX_BUFFER,
1197 chunks);
1198 if (num_regs < vport->num_bufq) {
1199 ret = -EINVAL;
1200 goto free_reg_vals;
1201 }
1202
1203 num_regs = __idpf_queue_reg_init(vport, reg_vals, num_regs,
1204 VIRTCHNL2_QUEUE_TYPE_RX_BUFFER);
1205 if (num_regs < vport->num_bufq) {
1206 ret = -EINVAL;
1207 goto free_reg_vals;
1208 }
1209 } else {
1210 num_regs = idpf_vport_get_q_reg(reg_vals, IDPF_LARGE_MAX_Q,
1211 VIRTCHNL2_QUEUE_TYPE_RX,
1212 chunks);
1213 if (num_regs < vport->num_rxq) {
1214 ret = -EINVAL;
1215 goto free_reg_vals;
1216 }
1217
1218 num_regs = __idpf_queue_reg_init(vport, reg_vals, num_regs,
1219 VIRTCHNL2_QUEUE_TYPE_RX);
1220 if (num_regs < vport->num_rxq) {
1221 ret = -EINVAL;
1222 goto free_reg_vals;
1223 }
1224 }
1225
1226free_reg_vals:
1227 kfree(reg_vals);
1228
1229 return ret;
1230}
1231
1232/**
1233 * idpf_send_create_vport_msg - Send virtchnl create vport message
1234 * @adapter: Driver specific private structure
1235 * @max_q: vport max queue info
1236 *
1237 * send virtchnl creae vport message
1238 *
1239 * Returns 0 on success, negative on failure
1240 */
1241int idpf_send_create_vport_msg(struct idpf_adapter *adapter,
1242 struct idpf_vport_max_q *max_q)
1243{
1244 struct virtchnl2_create_vport *vport_msg;
1245 struct idpf_vc_xn_params xn_params = {};
1246 u16 idx = adapter->next_vport;
1247 int err, buf_size;
1248 ssize_t reply_sz;
1249
1250 buf_size = sizeof(struct virtchnl2_create_vport);
1251 if (!adapter->vport_params_reqd[idx]) {
1252 adapter->vport_params_reqd[idx] = kzalloc(buf_size,
1253 GFP_KERNEL);
1254 if (!adapter->vport_params_reqd[idx])
1255 return -ENOMEM;
1256 }
1257
1258 vport_msg = adapter->vport_params_reqd[idx];
1259 vport_msg->vport_type = cpu_to_le16(VIRTCHNL2_VPORT_TYPE_DEFAULT);
1260 vport_msg->vport_index = cpu_to_le16(idx);
1261
1262 if (adapter->req_tx_splitq || !IS_ENABLED(CONFIG_IDPF_SINGLEQ))
1263 vport_msg->txq_model = cpu_to_le16(VIRTCHNL2_QUEUE_MODEL_SPLIT);
1264 else
1265 vport_msg->txq_model = cpu_to_le16(VIRTCHNL2_QUEUE_MODEL_SINGLE);
1266
1267 if (adapter->req_rx_splitq || !IS_ENABLED(CONFIG_IDPF_SINGLEQ))
1268 vport_msg->rxq_model = cpu_to_le16(VIRTCHNL2_QUEUE_MODEL_SPLIT);
1269 else
1270 vport_msg->rxq_model = cpu_to_le16(VIRTCHNL2_QUEUE_MODEL_SINGLE);
1271
1272 err = idpf_vport_calc_total_qs(adapter, idx, vport_msg, max_q);
1273 if (err) {
1274 dev_err(&adapter->pdev->dev, "Enough queues are not available");
1275
1276 return err;
1277 }
1278
1279 if (!adapter->vport_params_recvd[idx]) {
1280 adapter->vport_params_recvd[idx] = kzalloc(IDPF_CTLQ_MAX_BUF_LEN,
1281 GFP_KERNEL);
1282 if (!adapter->vport_params_recvd[idx]) {
1283 err = -ENOMEM;
1284 goto free_vport_params;
1285 }
1286 }
1287
1288 xn_params.vc_op = VIRTCHNL2_OP_CREATE_VPORT;
1289 xn_params.send_buf.iov_base = vport_msg;
1290 xn_params.send_buf.iov_len = buf_size;
1291 xn_params.recv_buf.iov_base = adapter->vport_params_recvd[idx];
1292 xn_params.recv_buf.iov_len = IDPF_CTLQ_MAX_BUF_LEN;
1293 xn_params.timeout_ms = IDPF_VC_XN_DEFAULT_TIMEOUT_MSEC;
1294 reply_sz = idpf_vc_xn_exec(adapter, &xn_params);
1295 if (reply_sz < 0) {
1296 err = reply_sz;
1297 goto free_vport_params;
1298 }
1299
1300 return 0;
1301
1302free_vport_params:
1303 kfree(adapter->vport_params_recvd[idx]);
1304 adapter->vport_params_recvd[idx] = NULL;
1305 kfree(adapter->vport_params_reqd[idx]);
1306 adapter->vport_params_reqd[idx] = NULL;
1307
1308 return err;
1309}
1310
1311/**
1312 * idpf_check_supported_desc_ids - Verify we have required descriptor support
1313 * @vport: virtual port structure
1314 *
1315 * Return 0 on success, error on failure
1316 */
1317int idpf_check_supported_desc_ids(struct idpf_vport *vport)
1318{
1319 struct idpf_adapter *adapter = vport->adapter;
1320 struct virtchnl2_create_vport *vport_msg;
1321 u64 rx_desc_ids, tx_desc_ids;
1322
1323 vport_msg = adapter->vport_params_recvd[vport->idx];
1324
1325 if (!IS_ENABLED(CONFIG_IDPF_SINGLEQ) &&
1326 (vport_msg->rxq_model == VIRTCHNL2_QUEUE_MODEL_SINGLE ||
1327 vport_msg->txq_model == VIRTCHNL2_QUEUE_MODEL_SINGLE)) {
1328 pci_err(adapter->pdev, "singleq mode requested, but not compiled-in\n");
1329 return -EOPNOTSUPP;
1330 }
1331
1332 rx_desc_ids = le64_to_cpu(vport_msg->rx_desc_ids);
1333 tx_desc_ids = le64_to_cpu(vport_msg->tx_desc_ids);
1334
1335 if (idpf_is_queue_model_split(vport->rxq_model)) {
1336 if (!(rx_desc_ids & VIRTCHNL2_RXDID_2_FLEX_SPLITQ_M)) {
1337 dev_info(&adapter->pdev->dev, "Minimum RX descriptor support not provided, using the default\n");
1338 vport_msg->rx_desc_ids = cpu_to_le64(VIRTCHNL2_RXDID_2_FLEX_SPLITQ_M);
1339 }
1340 } else {
1341 if (!(rx_desc_ids & VIRTCHNL2_RXDID_2_FLEX_SQ_NIC_M))
1342 vport->base_rxd = true;
1343 }
1344
1345 if (!idpf_is_queue_model_split(vport->txq_model))
1346 return 0;
1347
1348 if ((tx_desc_ids & MIN_SUPPORT_TXDID) != MIN_SUPPORT_TXDID) {
1349 dev_info(&adapter->pdev->dev, "Minimum TX descriptor support not provided, using the default\n");
1350 vport_msg->tx_desc_ids = cpu_to_le64(MIN_SUPPORT_TXDID);
1351 }
1352
1353 return 0;
1354}
1355
1356/**
1357 * idpf_send_destroy_vport_msg - Send virtchnl destroy vport message
1358 * @vport: virtual port data structure
1359 *
1360 * Send virtchnl destroy vport message. Returns 0 on success, negative on
1361 * failure.
1362 */
1363int idpf_send_destroy_vport_msg(struct idpf_vport *vport)
1364{
1365 struct idpf_vc_xn_params xn_params = {};
1366 struct virtchnl2_vport v_id;
1367 ssize_t reply_sz;
1368
1369 v_id.vport_id = cpu_to_le32(vport->vport_id);
1370
1371 xn_params.vc_op = VIRTCHNL2_OP_DESTROY_VPORT;
1372 xn_params.send_buf.iov_base = &v_id;
1373 xn_params.send_buf.iov_len = sizeof(v_id);
1374 xn_params.timeout_ms = IDPF_VC_XN_MIN_TIMEOUT_MSEC;
1375 reply_sz = idpf_vc_xn_exec(vport->adapter, &xn_params);
1376
1377 return reply_sz < 0 ? reply_sz : 0;
1378}
1379
1380/**
1381 * idpf_send_enable_vport_msg - Send virtchnl enable vport message
1382 * @vport: virtual port data structure
1383 *
1384 * Send enable vport virtchnl message. Returns 0 on success, negative on
1385 * failure.
1386 */
1387int idpf_send_enable_vport_msg(struct idpf_vport *vport)
1388{
1389 struct idpf_vc_xn_params xn_params = {};
1390 struct virtchnl2_vport v_id;
1391 ssize_t reply_sz;
1392
1393 v_id.vport_id = cpu_to_le32(vport->vport_id);
1394
1395 xn_params.vc_op = VIRTCHNL2_OP_ENABLE_VPORT;
1396 xn_params.send_buf.iov_base = &v_id;
1397 xn_params.send_buf.iov_len = sizeof(v_id);
1398 xn_params.timeout_ms = IDPF_VC_XN_DEFAULT_TIMEOUT_MSEC;
1399 reply_sz = idpf_vc_xn_exec(vport->adapter, &xn_params);
1400
1401 return reply_sz < 0 ? reply_sz : 0;
1402}
1403
1404/**
1405 * idpf_send_disable_vport_msg - Send virtchnl disable vport message
1406 * @vport: virtual port data structure
1407 *
1408 * Send disable vport virtchnl message. Returns 0 on success, negative on
1409 * failure.
1410 */
1411int idpf_send_disable_vport_msg(struct idpf_vport *vport)
1412{
1413 struct idpf_vc_xn_params xn_params = {};
1414 struct virtchnl2_vport v_id;
1415 ssize_t reply_sz;
1416
1417 v_id.vport_id = cpu_to_le32(vport->vport_id);
1418
1419 xn_params.vc_op = VIRTCHNL2_OP_DISABLE_VPORT;
1420 xn_params.send_buf.iov_base = &v_id;
1421 xn_params.send_buf.iov_len = sizeof(v_id);
1422 xn_params.timeout_ms = IDPF_VC_XN_MIN_TIMEOUT_MSEC;
1423 reply_sz = idpf_vc_xn_exec(vport->adapter, &xn_params);
1424
1425 return reply_sz < 0 ? reply_sz : 0;
1426}
1427
1428/**
1429 * idpf_send_config_tx_queues_msg - Send virtchnl config tx queues message
1430 * @vport: virtual port data structure
1431 *
1432 * Send config tx queues virtchnl message. Returns 0 on success, negative on
1433 * failure.
1434 */
1435static int idpf_send_config_tx_queues_msg(struct idpf_vport *vport)
1436{
1437 struct virtchnl2_config_tx_queues *ctq __free(kfree) = NULL;
1438 struct virtchnl2_txq_info *qi __free(kfree) = NULL;
1439 struct idpf_vc_xn_params xn_params = {};
1440 u32 config_sz, chunk_sz, buf_sz;
1441 int totqs, num_msgs, num_chunks;
1442 ssize_t reply_sz;
1443 int i, k = 0;
1444
1445 totqs = vport->num_txq + vport->num_complq;
1446 qi = kcalloc(totqs, sizeof(struct virtchnl2_txq_info), GFP_KERNEL);
1447 if (!qi)
1448 return -ENOMEM;
1449
1450 /* Populate the queue info buffer with all queue context info */
1451 for (i = 0; i < vport->num_txq_grp; i++) {
1452 struct idpf_txq_group *tx_qgrp = &vport->txq_grps[i];
1453 int j, sched_mode;
1454
1455 for (j = 0; j < tx_qgrp->num_txq; j++, k++) {
1456 qi[k].queue_id =
1457 cpu_to_le32(tx_qgrp->txqs[j]->q_id);
1458 qi[k].model =
1459 cpu_to_le16(vport->txq_model);
1460 qi[k].type =
1461 cpu_to_le32(VIRTCHNL2_QUEUE_TYPE_TX);
1462 qi[k].ring_len =
1463 cpu_to_le16(tx_qgrp->txqs[j]->desc_count);
1464 qi[k].dma_ring_addr =
1465 cpu_to_le64(tx_qgrp->txqs[j]->dma);
1466 if (idpf_is_queue_model_split(vport->txq_model)) {
1467 struct idpf_tx_queue *q = tx_qgrp->txqs[j];
1468
1469 qi[k].tx_compl_queue_id =
1470 cpu_to_le16(tx_qgrp->complq->q_id);
1471 qi[k].relative_queue_id = cpu_to_le16(j);
1472
1473 if (idpf_queue_has(FLOW_SCH_EN, q))
1474 qi[k].sched_mode =
1475 cpu_to_le16(VIRTCHNL2_TXQ_SCHED_MODE_FLOW);
1476 else
1477 qi[k].sched_mode =
1478 cpu_to_le16(VIRTCHNL2_TXQ_SCHED_MODE_QUEUE);
1479 } else {
1480 qi[k].sched_mode =
1481 cpu_to_le16(VIRTCHNL2_TXQ_SCHED_MODE_QUEUE);
1482 }
1483 }
1484
1485 if (!idpf_is_queue_model_split(vport->txq_model))
1486 continue;
1487
1488 qi[k].queue_id = cpu_to_le32(tx_qgrp->complq->q_id);
1489 qi[k].model = cpu_to_le16(vport->txq_model);
1490 qi[k].type = cpu_to_le32(VIRTCHNL2_QUEUE_TYPE_TX_COMPLETION);
1491 qi[k].ring_len = cpu_to_le16(tx_qgrp->complq->desc_count);
1492 qi[k].dma_ring_addr = cpu_to_le64(tx_qgrp->complq->dma);
1493
1494 if (idpf_queue_has(FLOW_SCH_EN, tx_qgrp->complq))
1495 sched_mode = VIRTCHNL2_TXQ_SCHED_MODE_FLOW;
1496 else
1497 sched_mode = VIRTCHNL2_TXQ_SCHED_MODE_QUEUE;
1498 qi[k].sched_mode = cpu_to_le16(sched_mode);
1499
1500 k++;
1501 }
1502
1503 /* Make sure accounting agrees */
1504 if (k != totqs)
1505 return -EINVAL;
1506
1507 /* Chunk up the queue contexts into multiple messages to avoid
1508 * sending a control queue message buffer that is too large
1509 */
1510 config_sz = sizeof(struct virtchnl2_config_tx_queues);
1511 chunk_sz = sizeof(struct virtchnl2_txq_info);
1512
1513 num_chunks = min_t(u32, IDPF_NUM_CHUNKS_PER_MSG(config_sz, chunk_sz),
1514 totqs);
1515 num_msgs = DIV_ROUND_UP(totqs, num_chunks);
1516
1517 buf_sz = struct_size(ctq, qinfo, num_chunks);
1518 ctq = kzalloc(buf_sz, GFP_KERNEL);
1519 if (!ctq)
1520 return -ENOMEM;
1521
1522 xn_params.vc_op = VIRTCHNL2_OP_CONFIG_TX_QUEUES;
1523 xn_params.timeout_ms = IDPF_VC_XN_DEFAULT_TIMEOUT_MSEC;
1524
1525 for (i = 0, k = 0; i < num_msgs; i++) {
1526 memset(ctq, 0, buf_sz);
1527 ctq->vport_id = cpu_to_le32(vport->vport_id);
1528 ctq->num_qinfo = cpu_to_le16(num_chunks);
1529 memcpy(ctq->qinfo, &qi[k], chunk_sz * num_chunks);
1530
1531 xn_params.send_buf.iov_base = ctq;
1532 xn_params.send_buf.iov_len = buf_sz;
1533 reply_sz = idpf_vc_xn_exec(vport->adapter, &xn_params);
1534 if (reply_sz < 0)
1535 return reply_sz;
1536
1537 k += num_chunks;
1538 totqs -= num_chunks;
1539 num_chunks = min(num_chunks, totqs);
1540 /* Recalculate buffer size */
1541 buf_sz = struct_size(ctq, qinfo, num_chunks);
1542 }
1543
1544 return 0;
1545}
1546
1547/**
1548 * idpf_send_config_rx_queues_msg - Send virtchnl config rx queues message
1549 * @vport: virtual port data structure
1550 *
1551 * Send config rx queues virtchnl message. Returns 0 on success, negative on
1552 * failure.
1553 */
1554static int idpf_send_config_rx_queues_msg(struct idpf_vport *vport)
1555{
1556 struct virtchnl2_config_rx_queues *crq __free(kfree) = NULL;
1557 struct virtchnl2_rxq_info *qi __free(kfree) = NULL;
1558 struct idpf_vc_xn_params xn_params = {};
1559 u32 config_sz, chunk_sz, buf_sz;
1560 int totqs, num_msgs, num_chunks;
1561 ssize_t reply_sz;
1562 int i, k = 0;
1563
1564 totqs = vport->num_rxq + vport->num_bufq;
1565 qi = kcalloc(totqs, sizeof(struct virtchnl2_rxq_info), GFP_KERNEL);
1566 if (!qi)
1567 return -ENOMEM;
1568
1569 /* Populate the queue info buffer with all queue context info */
1570 for (i = 0; i < vport->num_rxq_grp; i++) {
1571 struct idpf_rxq_group *rx_qgrp = &vport->rxq_grps[i];
1572 u16 num_rxq;
1573 int j;
1574
1575 if (!idpf_is_queue_model_split(vport->rxq_model))
1576 goto setup_rxqs;
1577
1578 for (j = 0; j < vport->num_bufqs_per_qgrp; j++, k++) {
1579 struct idpf_buf_queue *bufq =
1580 &rx_qgrp->splitq.bufq_sets[j].bufq;
1581
1582 qi[k].queue_id = cpu_to_le32(bufq->q_id);
1583 qi[k].model = cpu_to_le16(vport->rxq_model);
1584 qi[k].type =
1585 cpu_to_le32(VIRTCHNL2_QUEUE_TYPE_RX_BUFFER);
1586 qi[k].desc_ids = cpu_to_le64(VIRTCHNL2_RXDID_2_FLEX_SPLITQ_M);
1587 qi[k].ring_len = cpu_to_le16(bufq->desc_count);
1588 qi[k].dma_ring_addr = cpu_to_le64(bufq->dma);
1589 qi[k].data_buffer_size = cpu_to_le32(bufq->rx_buf_size);
1590 qi[k].buffer_notif_stride = IDPF_RX_BUF_STRIDE;
1591 qi[k].rx_buffer_low_watermark =
1592 cpu_to_le16(bufq->rx_buffer_low_watermark);
1593 if (idpf_is_feature_ena(vport, NETIF_F_GRO_HW))
1594 qi[k].qflags |= cpu_to_le16(VIRTCHNL2_RXQ_RSC);
1595 }
1596
1597setup_rxqs:
1598 if (idpf_is_queue_model_split(vport->rxq_model))
1599 num_rxq = rx_qgrp->splitq.num_rxq_sets;
1600 else
1601 num_rxq = rx_qgrp->singleq.num_rxq;
1602
1603 for (j = 0; j < num_rxq; j++, k++) {
1604 const struct idpf_bufq_set *sets;
1605 struct idpf_rx_queue *rxq;
1606
1607 if (!idpf_is_queue_model_split(vport->rxq_model)) {
1608 rxq = rx_qgrp->singleq.rxqs[j];
1609 goto common_qi_fields;
1610 }
1611
1612 rxq = &rx_qgrp->splitq.rxq_sets[j]->rxq;
1613 sets = rxq->bufq_sets;
1614
1615 /* In splitq mode, RXQ buffer size should be
1616 * set to that of the first buffer queue
1617 * associated with this RXQ.
1618 */
1619 rxq->rx_buf_size = sets[0].bufq.rx_buf_size;
1620
1621 qi[k].rx_bufq1_id = cpu_to_le16(sets[0].bufq.q_id);
1622 if (vport->num_bufqs_per_qgrp > IDPF_SINGLE_BUFQ_PER_RXQ_GRP) {
1623 qi[k].bufq2_ena = IDPF_BUFQ2_ENA;
1624 qi[k].rx_bufq2_id =
1625 cpu_to_le16(sets[1].bufq.q_id);
1626 }
1627 qi[k].rx_buffer_low_watermark =
1628 cpu_to_le16(rxq->rx_buffer_low_watermark);
1629 if (idpf_is_feature_ena(vport, NETIF_F_GRO_HW))
1630 qi[k].qflags |= cpu_to_le16(VIRTCHNL2_RXQ_RSC);
1631
1632 rxq->rx_hbuf_size = sets[0].bufq.rx_hbuf_size;
1633
1634 if (idpf_queue_has(HSPLIT_EN, rxq)) {
1635 qi[k].qflags |=
1636 cpu_to_le16(VIRTCHNL2_RXQ_HDR_SPLIT);
1637 qi[k].hdr_buffer_size =
1638 cpu_to_le16(rxq->rx_hbuf_size);
1639 }
1640
1641common_qi_fields:
1642 qi[k].queue_id = cpu_to_le32(rxq->q_id);
1643 qi[k].model = cpu_to_le16(vport->rxq_model);
1644 qi[k].type = cpu_to_le32(VIRTCHNL2_QUEUE_TYPE_RX);
1645 qi[k].ring_len = cpu_to_le16(rxq->desc_count);
1646 qi[k].dma_ring_addr = cpu_to_le64(rxq->dma);
1647 qi[k].max_pkt_size = cpu_to_le32(rxq->rx_max_pkt_size);
1648 qi[k].data_buffer_size = cpu_to_le32(rxq->rx_buf_size);
1649 qi[k].qflags |=
1650 cpu_to_le16(VIRTCHNL2_RX_DESC_SIZE_32BYTE);
1651 qi[k].desc_ids = cpu_to_le64(rxq->rxdids);
1652 }
1653 }
1654
1655 /* Make sure accounting agrees */
1656 if (k != totqs)
1657 return -EINVAL;
1658
1659 /* Chunk up the queue contexts into multiple messages to avoid
1660 * sending a control queue message buffer that is too large
1661 */
1662 config_sz = sizeof(struct virtchnl2_config_rx_queues);
1663 chunk_sz = sizeof(struct virtchnl2_rxq_info);
1664
1665 num_chunks = min_t(u32, IDPF_NUM_CHUNKS_PER_MSG(config_sz, chunk_sz),
1666 totqs);
1667 num_msgs = DIV_ROUND_UP(totqs, num_chunks);
1668
1669 buf_sz = struct_size(crq, qinfo, num_chunks);
1670 crq = kzalloc(buf_sz, GFP_KERNEL);
1671 if (!crq)
1672 return -ENOMEM;
1673
1674 xn_params.vc_op = VIRTCHNL2_OP_CONFIG_RX_QUEUES;
1675 xn_params.timeout_ms = IDPF_VC_XN_DEFAULT_TIMEOUT_MSEC;
1676
1677 for (i = 0, k = 0; i < num_msgs; i++) {
1678 memset(crq, 0, buf_sz);
1679 crq->vport_id = cpu_to_le32(vport->vport_id);
1680 crq->num_qinfo = cpu_to_le16(num_chunks);
1681 memcpy(crq->qinfo, &qi[k], chunk_sz * num_chunks);
1682
1683 xn_params.send_buf.iov_base = crq;
1684 xn_params.send_buf.iov_len = buf_sz;
1685 reply_sz = idpf_vc_xn_exec(vport->adapter, &xn_params);
1686 if (reply_sz < 0)
1687 return reply_sz;
1688
1689 k += num_chunks;
1690 totqs -= num_chunks;
1691 num_chunks = min(num_chunks, totqs);
1692 /* Recalculate buffer size */
1693 buf_sz = struct_size(crq, qinfo, num_chunks);
1694 }
1695
1696 return 0;
1697}
1698
1699/**
1700 * idpf_send_ena_dis_queues_msg - Send virtchnl enable or disable
1701 * queues message
1702 * @vport: virtual port data structure
1703 * @ena: if true enable, false disable
1704 *
1705 * Send enable or disable queues virtchnl message. Returns 0 on success,
1706 * negative on failure.
1707 */
1708static int idpf_send_ena_dis_queues_msg(struct idpf_vport *vport, bool ena)
1709{
1710 struct virtchnl2_del_ena_dis_queues *eq __free(kfree) = NULL;
1711 struct virtchnl2_queue_chunk *qc __free(kfree) = NULL;
1712 u32 num_msgs, num_chunks, num_txq, num_rxq, num_q;
1713 struct idpf_vc_xn_params xn_params = {};
1714 struct virtchnl2_queue_chunks *qcs;
1715 u32 config_sz, chunk_sz, buf_sz;
1716 ssize_t reply_sz;
1717 int i, j, k = 0;
1718
1719 num_txq = vport->num_txq + vport->num_complq;
1720 num_rxq = vport->num_rxq + vport->num_bufq;
1721 num_q = num_txq + num_rxq;
1722 buf_sz = sizeof(struct virtchnl2_queue_chunk) * num_q;
1723 qc = kzalloc(buf_sz, GFP_KERNEL);
1724 if (!qc)
1725 return -ENOMEM;
1726
1727 for (i = 0; i < vport->num_txq_grp; i++) {
1728 struct idpf_txq_group *tx_qgrp = &vport->txq_grps[i];
1729
1730 for (j = 0; j < tx_qgrp->num_txq; j++, k++) {
1731 qc[k].type = cpu_to_le32(VIRTCHNL2_QUEUE_TYPE_TX);
1732 qc[k].start_queue_id = cpu_to_le32(tx_qgrp->txqs[j]->q_id);
1733 qc[k].num_queues = cpu_to_le32(IDPF_NUMQ_PER_CHUNK);
1734 }
1735 }
1736 if (vport->num_txq != k)
1737 return -EINVAL;
1738
1739 if (!idpf_is_queue_model_split(vport->txq_model))
1740 goto setup_rx;
1741
1742 for (i = 0; i < vport->num_txq_grp; i++, k++) {
1743 struct idpf_txq_group *tx_qgrp = &vport->txq_grps[i];
1744
1745 qc[k].type = cpu_to_le32(VIRTCHNL2_QUEUE_TYPE_TX_COMPLETION);
1746 qc[k].start_queue_id = cpu_to_le32(tx_qgrp->complq->q_id);
1747 qc[k].num_queues = cpu_to_le32(IDPF_NUMQ_PER_CHUNK);
1748 }
1749 if (vport->num_complq != (k - vport->num_txq))
1750 return -EINVAL;
1751
1752setup_rx:
1753 for (i = 0; i < vport->num_rxq_grp; i++) {
1754 struct idpf_rxq_group *rx_qgrp = &vport->rxq_grps[i];
1755
1756 if (idpf_is_queue_model_split(vport->rxq_model))
1757 num_rxq = rx_qgrp->splitq.num_rxq_sets;
1758 else
1759 num_rxq = rx_qgrp->singleq.num_rxq;
1760
1761 for (j = 0; j < num_rxq; j++, k++) {
1762 if (idpf_is_queue_model_split(vport->rxq_model)) {
1763 qc[k].start_queue_id =
1764 cpu_to_le32(rx_qgrp->splitq.rxq_sets[j]->rxq.q_id);
1765 qc[k].type =
1766 cpu_to_le32(VIRTCHNL2_QUEUE_TYPE_RX);
1767 } else {
1768 qc[k].start_queue_id =
1769 cpu_to_le32(rx_qgrp->singleq.rxqs[j]->q_id);
1770 qc[k].type =
1771 cpu_to_le32(VIRTCHNL2_QUEUE_TYPE_RX);
1772 }
1773 qc[k].num_queues = cpu_to_le32(IDPF_NUMQ_PER_CHUNK);
1774 }
1775 }
1776 if (vport->num_rxq != k - (vport->num_txq + vport->num_complq))
1777 return -EINVAL;
1778
1779 if (!idpf_is_queue_model_split(vport->rxq_model))
1780 goto send_msg;
1781
1782 for (i = 0; i < vport->num_rxq_grp; i++) {
1783 struct idpf_rxq_group *rx_qgrp = &vport->rxq_grps[i];
1784
1785 for (j = 0; j < vport->num_bufqs_per_qgrp; j++, k++) {
1786 const struct idpf_buf_queue *q;
1787
1788 q = &rx_qgrp->splitq.bufq_sets[j].bufq;
1789 qc[k].type =
1790 cpu_to_le32(VIRTCHNL2_QUEUE_TYPE_RX_BUFFER);
1791 qc[k].start_queue_id = cpu_to_le32(q->q_id);
1792 qc[k].num_queues = cpu_to_le32(IDPF_NUMQ_PER_CHUNK);
1793 }
1794 }
1795 if (vport->num_bufq != k - (vport->num_txq +
1796 vport->num_complq +
1797 vport->num_rxq))
1798 return -EINVAL;
1799
1800send_msg:
1801 /* Chunk up the queue info into multiple messages */
1802 config_sz = sizeof(struct virtchnl2_del_ena_dis_queues);
1803 chunk_sz = sizeof(struct virtchnl2_queue_chunk);
1804
1805 num_chunks = min_t(u32, IDPF_NUM_CHUNKS_PER_MSG(config_sz, chunk_sz),
1806 num_q);
1807 num_msgs = DIV_ROUND_UP(num_q, num_chunks);
1808
1809 buf_sz = struct_size(eq, chunks.chunks, num_chunks);
1810 eq = kzalloc(buf_sz, GFP_KERNEL);
1811 if (!eq)
1812 return -ENOMEM;
1813
1814 if (ena) {
1815 xn_params.vc_op = VIRTCHNL2_OP_ENABLE_QUEUES;
1816 xn_params.timeout_ms = IDPF_VC_XN_DEFAULT_TIMEOUT_MSEC;
1817 } else {
1818 xn_params.vc_op = VIRTCHNL2_OP_DISABLE_QUEUES;
1819 xn_params.timeout_ms = IDPF_VC_XN_MIN_TIMEOUT_MSEC;
1820 }
1821
1822 for (i = 0, k = 0; i < num_msgs; i++) {
1823 memset(eq, 0, buf_sz);
1824 eq->vport_id = cpu_to_le32(vport->vport_id);
1825 eq->chunks.num_chunks = cpu_to_le16(num_chunks);
1826 qcs = &eq->chunks;
1827 memcpy(qcs->chunks, &qc[k], chunk_sz * num_chunks);
1828
1829 xn_params.send_buf.iov_base = eq;
1830 xn_params.send_buf.iov_len = buf_sz;
1831 reply_sz = idpf_vc_xn_exec(vport->adapter, &xn_params);
1832 if (reply_sz < 0)
1833 return reply_sz;
1834
1835 k += num_chunks;
1836 num_q -= num_chunks;
1837 num_chunks = min(num_chunks, num_q);
1838 /* Recalculate buffer size */
1839 buf_sz = struct_size(eq, chunks.chunks, num_chunks);
1840 }
1841
1842 return 0;
1843}
1844
1845/**
1846 * idpf_send_map_unmap_queue_vector_msg - Send virtchnl map or unmap queue
1847 * vector message
1848 * @vport: virtual port data structure
1849 * @map: true for map and false for unmap
1850 *
1851 * Send map or unmap queue vector virtchnl message. Returns 0 on success,
1852 * negative on failure.
1853 */
1854int idpf_send_map_unmap_queue_vector_msg(struct idpf_vport *vport, bool map)
1855{
1856 struct virtchnl2_queue_vector_maps *vqvm __free(kfree) = NULL;
1857 struct virtchnl2_queue_vector *vqv __free(kfree) = NULL;
1858 struct idpf_vc_xn_params xn_params = {};
1859 u32 config_sz, chunk_sz, buf_sz;
1860 u32 num_msgs, num_chunks, num_q;
1861 ssize_t reply_sz;
1862 int i, j, k = 0;
1863
1864 num_q = vport->num_txq + vport->num_rxq;
1865
1866 buf_sz = sizeof(struct virtchnl2_queue_vector) * num_q;
1867 vqv = kzalloc(buf_sz, GFP_KERNEL);
1868 if (!vqv)
1869 return -ENOMEM;
1870
1871 for (i = 0; i < vport->num_txq_grp; i++) {
1872 struct idpf_txq_group *tx_qgrp = &vport->txq_grps[i];
1873
1874 for (j = 0; j < tx_qgrp->num_txq; j++, k++) {
1875 vqv[k].queue_type =
1876 cpu_to_le32(VIRTCHNL2_QUEUE_TYPE_TX);
1877 vqv[k].queue_id = cpu_to_le32(tx_qgrp->txqs[j]->q_id);
1878
1879 if (idpf_is_queue_model_split(vport->txq_model)) {
1880 vqv[k].vector_id =
1881 cpu_to_le16(tx_qgrp->complq->q_vector->v_idx);
1882 vqv[k].itr_idx =
1883 cpu_to_le32(tx_qgrp->complq->q_vector->tx_itr_idx);
1884 } else {
1885 vqv[k].vector_id =
1886 cpu_to_le16(tx_qgrp->txqs[j]->q_vector->v_idx);
1887 vqv[k].itr_idx =
1888 cpu_to_le32(tx_qgrp->txqs[j]->q_vector->tx_itr_idx);
1889 }
1890 }
1891 }
1892
1893 if (vport->num_txq != k)
1894 return -EINVAL;
1895
1896 for (i = 0; i < vport->num_rxq_grp; i++) {
1897 struct idpf_rxq_group *rx_qgrp = &vport->rxq_grps[i];
1898 u16 num_rxq;
1899
1900 if (idpf_is_queue_model_split(vport->rxq_model))
1901 num_rxq = rx_qgrp->splitq.num_rxq_sets;
1902 else
1903 num_rxq = rx_qgrp->singleq.num_rxq;
1904
1905 for (j = 0; j < num_rxq; j++, k++) {
1906 struct idpf_rx_queue *rxq;
1907
1908 if (idpf_is_queue_model_split(vport->rxq_model))
1909 rxq = &rx_qgrp->splitq.rxq_sets[j]->rxq;
1910 else
1911 rxq = rx_qgrp->singleq.rxqs[j];
1912
1913 vqv[k].queue_type =
1914 cpu_to_le32(VIRTCHNL2_QUEUE_TYPE_RX);
1915 vqv[k].queue_id = cpu_to_le32(rxq->q_id);
1916 vqv[k].vector_id = cpu_to_le16(rxq->q_vector->v_idx);
1917 vqv[k].itr_idx = cpu_to_le32(rxq->q_vector->rx_itr_idx);
1918 }
1919 }
1920
1921 if (idpf_is_queue_model_split(vport->txq_model)) {
1922 if (vport->num_rxq != k - vport->num_complq)
1923 return -EINVAL;
1924 } else {
1925 if (vport->num_rxq != k - vport->num_txq)
1926 return -EINVAL;
1927 }
1928
1929 /* Chunk up the vector info into multiple messages */
1930 config_sz = sizeof(struct virtchnl2_queue_vector_maps);
1931 chunk_sz = sizeof(struct virtchnl2_queue_vector);
1932
1933 num_chunks = min_t(u32, IDPF_NUM_CHUNKS_PER_MSG(config_sz, chunk_sz),
1934 num_q);
1935 num_msgs = DIV_ROUND_UP(num_q, num_chunks);
1936
1937 buf_sz = struct_size(vqvm, qv_maps, num_chunks);
1938 vqvm = kzalloc(buf_sz, GFP_KERNEL);
1939 if (!vqvm)
1940 return -ENOMEM;
1941
1942 if (map) {
1943 xn_params.vc_op = VIRTCHNL2_OP_MAP_QUEUE_VECTOR;
1944 xn_params.timeout_ms = IDPF_VC_XN_DEFAULT_TIMEOUT_MSEC;
1945 } else {
1946 xn_params.vc_op = VIRTCHNL2_OP_UNMAP_QUEUE_VECTOR;
1947 xn_params.timeout_ms = IDPF_VC_XN_MIN_TIMEOUT_MSEC;
1948 }
1949
1950 for (i = 0, k = 0; i < num_msgs; i++) {
1951 memset(vqvm, 0, buf_sz);
1952 xn_params.send_buf.iov_base = vqvm;
1953 xn_params.send_buf.iov_len = buf_sz;
1954 vqvm->vport_id = cpu_to_le32(vport->vport_id);
1955 vqvm->num_qv_maps = cpu_to_le16(num_chunks);
1956 memcpy(vqvm->qv_maps, &vqv[k], chunk_sz * num_chunks);
1957
1958 reply_sz = idpf_vc_xn_exec(vport->adapter, &xn_params);
1959 if (reply_sz < 0)
1960 return reply_sz;
1961
1962 k += num_chunks;
1963 num_q -= num_chunks;
1964 num_chunks = min(num_chunks, num_q);
1965 /* Recalculate buffer size */
1966 buf_sz = struct_size(vqvm, qv_maps, num_chunks);
1967 }
1968
1969 return 0;
1970}
1971
1972/**
1973 * idpf_send_enable_queues_msg - send enable queues virtchnl message
1974 * @vport: Virtual port private data structure
1975 *
1976 * Will send enable queues virtchnl message. Returns 0 on success, negative on
1977 * failure.
1978 */
1979int idpf_send_enable_queues_msg(struct idpf_vport *vport)
1980{
1981 return idpf_send_ena_dis_queues_msg(vport, true);
1982}
1983
1984/**
1985 * idpf_send_disable_queues_msg - send disable queues virtchnl message
1986 * @vport: Virtual port private data structure
1987 *
1988 * Will send disable queues virtchnl message. Returns 0 on success, negative
1989 * on failure.
1990 */
1991int idpf_send_disable_queues_msg(struct idpf_vport *vport)
1992{
1993 int err, i;
1994
1995 err = idpf_send_ena_dis_queues_msg(vport, false);
1996 if (err)
1997 return err;
1998
1999 /* switch to poll mode as interrupts will be disabled after disable
2000 * queues virtchnl message is sent
2001 */
2002 for (i = 0; i < vport->num_txq; i++)
2003 idpf_queue_set(POLL_MODE, vport->txqs[i]);
2004
2005 /* schedule the napi to receive all the marker packets */
2006 local_bh_disable();
2007 for (i = 0; i < vport->num_q_vectors; i++)
2008 napi_schedule(&vport->q_vectors[i].napi);
2009 local_bh_enable();
2010
2011 return idpf_wait_for_marker_event(vport);
2012}
2013
2014/**
2015 * idpf_convert_reg_to_queue_chunks - Copy queue chunk information to the right
2016 * structure
2017 * @dchunks: Destination chunks to store data to
2018 * @schunks: Source chunks to copy data from
2019 * @num_chunks: number of chunks to copy
2020 */
2021static void idpf_convert_reg_to_queue_chunks(struct virtchnl2_queue_chunk *dchunks,
2022 struct virtchnl2_queue_reg_chunk *schunks,
2023 u16 num_chunks)
2024{
2025 u16 i;
2026
2027 for (i = 0; i < num_chunks; i++) {
2028 dchunks[i].type = schunks[i].type;
2029 dchunks[i].start_queue_id = schunks[i].start_queue_id;
2030 dchunks[i].num_queues = schunks[i].num_queues;
2031 }
2032}
2033
2034/**
2035 * idpf_send_delete_queues_msg - send delete queues virtchnl message
2036 * @vport: Virtual port private data structure
2037 *
2038 * Will send delete queues virtchnl message. Return 0 on success, negative on
2039 * failure.
2040 */
2041int idpf_send_delete_queues_msg(struct idpf_vport *vport)
2042{
2043 struct virtchnl2_del_ena_dis_queues *eq __free(kfree) = NULL;
2044 struct virtchnl2_create_vport *vport_params;
2045 struct virtchnl2_queue_reg_chunks *chunks;
2046 struct idpf_vc_xn_params xn_params = {};
2047 struct idpf_vport_config *vport_config;
2048 u16 vport_idx = vport->idx;
2049 ssize_t reply_sz;
2050 u16 num_chunks;
2051 int buf_size;
2052
2053 vport_config = vport->adapter->vport_config[vport_idx];
2054 if (vport_config->req_qs_chunks) {
2055 chunks = &vport_config->req_qs_chunks->chunks;
2056 } else {
2057 vport_params = vport->adapter->vport_params_recvd[vport_idx];
2058 chunks = &vport_params->chunks;
2059 }
2060
2061 num_chunks = le16_to_cpu(chunks->num_chunks);
2062 buf_size = struct_size(eq, chunks.chunks, num_chunks);
2063
2064 eq = kzalloc(buf_size, GFP_KERNEL);
2065 if (!eq)
2066 return -ENOMEM;
2067
2068 eq->vport_id = cpu_to_le32(vport->vport_id);
2069 eq->chunks.num_chunks = cpu_to_le16(num_chunks);
2070
2071 idpf_convert_reg_to_queue_chunks(eq->chunks.chunks, chunks->chunks,
2072 num_chunks);
2073
2074 xn_params.vc_op = VIRTCHNL2_OP_DEL_QUEUES;
2075 xn_params.timeout_ms = IDPF_VC_XN_MIN_TIMEOUT_MSEC;
2076 xn_params.send_buf.iov_base = eq;
2077 xn_params.send_buf.iov_len = buf_size;
2078 reply_sz = idpf_vc_xn_exec(vport->adapter, &xn_params);
2079
2080 return reply_sz < 0 ? reply_sz : 0;
2081}
2082
2083/**
2084 * idpf_send_config_queues_msg - Send config queues virtchnl message
2085 * @vport: Virtual port private data structure
2086 *
2087 * Will send config queues virtchnl message. Returns 0 on success, negative on
2088 * failure.
2089 */
2090int idpf_send_config_queues_msg(struct idpf_vport *vport)
2091{
2092 int err;
2093
2094 err = idpf_send_config_tx_queues_msg(vport);
2095 if (err)
2096 return err;
2097
2098 return idpf_send_config_rx_queues_msg(vport);
2099}
2100
2101/**
2102 * idpf_send_add_queues_msg - Send virtchnl add queues message
2103 * @vport: Virtual port private data structure
2104 * @num_tx_q: number of transmit queues
2105 * @num_complq: number of transmit completion queues
2106 * @num_rx_q: number of receive queues
2107 * @num_rx_bufq: number of receive buffer queues
2108 *
2109 * Returns 0 on success, negative on failure. vport _MUST_ be const here as
2110 * we should not change any fields within vport itself in this function.
2111 */
2112int idpf_send_add_queues_msg(const struct idpf_vport *vport, u16 num_tx_q,
2113 u16 num_complq, u16 num_rx_q, u16 num_rx_bufq)
2114{
2115 struct virtchnl2_add_queues *vc_msg __free(kfree) = NULL;
2116 struct idpf_vc_xn_params xn_params = {};
2117 struct idpf_vport_config *vport_config;
2118 struct virtchnl2_add_queues aq = {};
2119 u16 vport_idx = vport->idx;
2120 ssize_t reply_sz;
2121 int size;
2122
2123 vc_msg = kzalloc(IDPF_CTLQ_MAX_BUF_LEN, GFP_KERNEL);
2124 if (!vc_msg)
2125 return -ENOMEM;
2126
2127 vport_config = vport->adapter->vport_config[vport_idx];
2128 kfree(vport_config->req_qs_chunks);
2129 vport_config->req_qs_chunks = NULL;
2130
2131 aq.vport_id = cpu_to_le32(vport->vport_id);
2132 aq.num_tx_q = cpu_to_le16(num_tx_q);
2133 aq.num_tx_complq = cpu_to_le16(num_complq);
2134 aq.num_rx_q = cpu_to_le16(num_rx_q);
2135 aq.num_rx_bufq = cpu_to_le16(num_rx_bufq);
2136
2137 xn_params.vc_op = VIRTCHNL2_OP_ADD_QUEUES;
2138 xn_params.timeout_ms = IDPF_VC_XN_DEFAULT_TIMEOUT_MSEC;
2139 xn_params.send_buf.iov_base = &aq;
2140 xn_params.send_buf.iov_len = sizeof(aq);
2141 xn_params.recv_buf.iov_base = vc_msg;
2142 xn_params.recv_buf.iov_len = IDPF_CTLQ_MAX_BUF_LEN;
2143 reply_sz = idpf_vc_xn_exec(vport->adapter, &xn_params);
2144 if (reply_sz < 0)
2145 return reply_sz;
2146
2147 /* compare vc_msg num queues with vport num queues */
2148 if (le16_to_cpu(vc_msg->num_tx_q) != num_tx_q ||
2149 le16_to_cpu(vc_msg->num_rx_q) != num_rx_q ||
2150 le16_to_cpu(vc_msg->num_tx_complq) != num_complq ||
2151 le16_to_cpu(vc_msg->num_rx_bufq) != num_rx_bufq)
2152 return -EINVAL;
2153
2154 size = struct_size(vc_msg, chunks.chunks,
2155 le16_to_cpu(vc_msg->chunks.num_chunks));
2156 if (reply_sz < size)
2157 return -EIO;
2158
2159 vport_config->req_qs_chunks = kmemdup(vc_msg, size, GFP_KERNEL);
2160 if (!vport_config->req_qs_chunks)
2161 return -ENOMEM;
2162
2163 return 0;
2164}
2165
2166/**
2167 * idpf_send_alloc_vectors_msg - Send virtchnl alloc vectors message
2168 * @adapter: Driver specific private structure
2169 * @num_vectors: number of vectors to be allocated
2170 *
2171 * Returns 0 on success, negative on failure.
2172 */
2173int idpf_send_alloc_vectors_msg(struct idpf_adapter *adapter, u16 num_vectors)
2174{
2175 struct virtchnl2_alloc_vectors *rcvd_vec __free(kfree) = NULL;
2176 struct idpf_vc_xn_params xn_params = {};
2177 struct virtchnl2_alloc_vectors ac = {};
2178 ssize_t reply_sz;
2179 u16 num_vchunks;
2180 int size;
2181
2182 ac.num_vectors = cpu_to_le16(num_vectors);
2183
2184 rcvd_vec = kzalloc(IDPF_CTLQ_MAX_BUF_LEN, GFP_KERNEL);
2185 if (!rcvd_vec)
2186 return -ENOMEM;
2187
2188 xn_params.vc_op = VIRTCHNL2_OP_ALLOC_VECTORS;
2189 xn_params.send_buf.iov_base = ∾
2190 xn_params.send_buf.iov_len = sizeof(ac);
2191 xn_params.recv_buf.iov_base = rcvd_vec;
2192 xn_params.recv_buf.iov_len = IDPF_CTLQ_MAX_BUF_LEN;
2193 xn_params.timeout_ms = IDPF_VC_XN_DEFAULT_TIMEOUT_MSEC;
2194 reply_sz = idpf_vc_xn_exec(adapter, &xn_params);
2195 if (reply_sz < 0)
2196 return reply_sz;
2197
2198 num_vchunks = le16_to_cpu(rcvd_vec->vchunks.num_vchunks);
2199 size = struct_size(rcvd_vec, vchunks.vchunks, num_vchunks);
2200 if (reply_sz < size)
2201 return -EIO;
2202
2203 if (size > IDPF_CTLQ_MAX_BUF_LEN)
2204 return -EINVAL;
2205
2206 kfree(adapter->req_vec_chunks);
2207 adapter->req_vec_chunks = kmemdup(rcvd_vec, size, GFP_KERNEL);
2208 if (!adapter->req_vec_chunks)
2209 return -ENOMEM;
2210
2211 if (le16_to_cpu(adapter->req_vec_chunks->num_vectors) < num_vectors) {
2212 kfree(adapter->req_vec_chunks);
2213 adapter->req_vec_chunks = NULL;
2214 return -EINVAL;
2215 }
2216
2217 return 0;
2218}
2219
2220/**
2221 * idpf_send_dealloc_vectors_msg - Send virtchnl de allocate vectors message
2222 * @adapter: Driver specific private structure
2223 *
2224 * Returns 0 on success, negative on failure.
2225 */
2226int idpf_send_dealloc_vectors_msg(struct idpf_adapter *adapter)
2227{
2228 struct virtchnl2_alloc_vectors *ac = adapter->req_vec_chunks;
2229 struct virtchnl2_vector_chunks *vcs = &ac->vchunks;
2230 struct idpf_vc_xn_params xn_params = {};
2231 ssize_t reply_sz;
2232 int buf_size;
2233
2234 buf_size = struct_size(vcs, vchunks, le16_to_cpu(vcs->num_vchunks));
2235
2236 xn_params.vc_op = VIRTCHNL2_OP_DEALLOC_VECTORS;
2237 xn_params.send_buf.iov_base = vcs;
2238 xn_params.send_buf.iov_len = buf_size;
2239 xn_params.timeout_ms = IDPF_VC_XN_MIN_TIMEOUT_MSEC;
2240 reply_sz = idpf_vc_xn_exec(adapter, &xn_params);
2241 if (reply_sz < 0)
2242 return reply_sz;
2243
2244 kfree(adapter->req_vec_chunks);
2245 adapter->req_vec_chunks = NULL;
2246
2247 return 0;
2248}
2249
2250/**
2251 * idpf_get_max_vfs - Get max number of vfs supported
2252 * @adapter: Driver specific private structure
2253 *
2254 * Returns max number of VFs
2255 */
2256static int idpf_get_max_vfs(struct idpf_adapter *adapter)
2257{
2258 return le16_to_cpu(adapter->caps.max_sriov_vfs);
2259}
2260
2261/**
2262 * idpf_send_set_sriov_vfs_msg - Send virtchnl set sriov vfs message
2263 * @adapter: Driver specific private structure
2264 * @num_vfs: number of virtual functions to be created
2265 *
2266 * Returns 0 on success, negative on failure.
2267 */
2268int idpf_send_set_sriov_vfs_msg(struct idpf_adapter *adapter, u16 num_vfs)
2269{
2270 struct virtchnl2_sriov_vfs_info svi = {};
2271 struct idpf_vc_xn_params xn_params = {};
2272 ssize_t reply_sz;
2273
2274 svi.num_vfs = cpu_to_le16(num_vfs);
2275 xn_params.vc_op = VIRTCHNL2_OP_SET_SRIOV_VFS;
2276 xn_params.timeout_ms = IDPF_VC_XN_DEFAULT_TIMEOUT_MSEC;
2277 xn_params.send_buf.iov_base = &svi;
2278 xn_params.send_buf.iov_len = sizeof(svi);
2279 reply_sz = idpf_vc_xn_exec(adapter, &xn_params);
2280
2281 return reply_sz < 0 ? reply_sz : 0;
2282}
2283
2284/**
2285 * idpf_send_get_stats_msg - Send virtchnl get statistics message
2286 * @vport: vport to get stats for
2287 *
2288 * Returns 0 on success, negative on failure.
2289 */
2290int idpf_send_get_stats_msg(struct idpf_vport *vport)
2291{
2292 struct idpf_netdev_priv *np = netdev_priv(vport->netdev);
2293 struct rtnl_link_stats64 *netstats = &np->netstats;
2294 struct virtchnl2_vport_stats stats_msg = {};
2295 struct idpf_vc_xn_params xn_params = {};
2296 ssize_t reply_sz;
2297
2298
2299 /* Don't send get_stats message if the link is down */
2300 if (np->state <= __IDPF_VPORT_DOWN)
2301 return 0;
2302
2303 stats_msg.vport_id = cpu_to_le32(vport->vport_id);
2304
2305 xn_params.vc_op = VIRTCHNL2_OP_GET_STATS;
2306 xn_params.send_buf.iov_base = &stats_msg;
2307 xn_params.send_buf.iov_len = sizeof(stats_msg);
2308 xn_params.recv_buf = xn_params.send_buf;
2309 xn_params.timeout_ms = IDPF_VC_XN_DEFAULT_TIMEOUT_MSEC;
2310
2311 reply_sz = idpf_vc_xn_exec(vport->adapter, &xn_params);
2312 if (reply_sz < 0)
2313 return reply_sz;
2314 if (reply_sz < sizeof(stats_msg))
2315 return -EIO;
2316
2317 spin_lock_bh(&np->stats_lock);
2318
2319 netstats->rx_packets = le64_to_cpu(stats_msg.rx_unicast) +
2320 le64_to_cpu(stats_msg.rx_multicast) +
2321 le64_to_cpu(stats_msg.rx_broadcast);
2322 netstats->tx_packets = le64_to_cpu(stats_msg.tx_unicast) +
2323 le64_to_cpu(stats_msg.tx_multicast) +
2324 le64_to_cpu(stats_msg.tx_broadcast);
2325 netstats->rx_bytes = le64_to_cpu(stats_msg.rx_bytes);
2326 netstats->tx_bytes = le64_to_cpu(stats_msg.tx_bytes);
2327 netstats->rx_errors = le64_to_cpu(stats_msg.rx_errors);
2328 netstats->tx_errors = le64_to_cpu(stats_msg.tx_errors);
2329 netstats->rx_dropped = le64_to_cpu(stats_msg.rx_discards);
2330 netstats->tx_dropped = le64_to_cpu(stats_msg.tx_discards);
2331
2332 vport->port_stats.vport_stats = stats_msg;
2333
2334 spin_unlock_bh(&np->stats_lock);
2335
2336 return 0;
2337}
2338
2339/**
2340 * idpf_send_get_set_rss_lut_msg - Send virtchnl get or set rss lut message
2341 * @vport: virtual port data structure
2342 * @get: flag to set or get rss look up table
2343 *
2344 * Returns 0 on success, negative on failure.
2345 */
2346int idpf_send_get_set_rss_lut_msg(struct idpf_vport *vport, bool get)
2347{
2348 struct virtchnl2_rss_lut *recv_rl __free(kfree) = NULL;
2349 struct virtchnl2_rss_lut *rl __free(kfree) = NULL;
2350 struct idpf_vc_xn_params xn_params = {};
2351 struct idpf_rss_data *rss_data;
2352 int buf_size, lut_buf_size;
2353 ssize_t reply_sz;
2354 int i;
2355
2356 rss_data =
2357 &vport->adapter->vport_config[vport->idx]->user_config.rss_data;
2358 buf_size = struct_size(rl, lut, rss_data->rss_lut_size);
2359 rl = kzalloc(buf_size, GFP_KERNEL);
2360 if (!rl)
2361 return -ENOMEM;
2362
2363 rl->vport_id = cpu_to_le32(vport->vport_id);
2364
2365 xn_params.timeout_ms = IDPF_VC_XN_DEFAULT_TIMEOUT_MSEC;
2366 xn_params.send_buf.iov_base = rl;
2367 xn_params.send_buf.iov_len = buf_size;
2368
2369 if (get) {
2370 recv_rl = kzalloc(IDPF_CTLQ_MAX_BUF_LEN, GFP_KERNEL);
2371 if (!recv_rl)
2372 return -ENOMEM;
2373 xn_params.vc_op = VIRTCHNL2_OP_GET_RSS_LUT;
2374 xn_params.recv_buf.iov_base = recv_rl;
2375 xn_params.recv_buf.iov_len = IDPF_CTLQ_MAX_BUF_LEN;
2376 } else {
2377 rl->lut_entries = cpu_to_le16(rss_data->rss_lut_size);
2378 for (i = 0; i < rss_data->rss_lut_size; i++)
2379 rl->lut[i] = cpu_to_le32(rss_data->rss_lut[i]);
2380
2381 xn_params.vc_op = VIRTCHNL2_OP_SET_RSS_LUT;
2382 }
2383 reply_sz = idpf_vc_xn_exec(vport->adapter, &xn_params);
2384 if (reply_sz < 0)
2385 return reply_sz;
2386 if (!get)
2387 return 0;
2388 if (reply_sz < sizeof(struct virtchnl2_rss_lut))
2389 return -EIO;
2390
2391 lut_buf_size = le16_to_cpu(recv_rl->lut_entries) * sizeof(u32);
2392 if (reply_sz < lut_buf_size)
2393 return -EIO;
2394
2395 /* size didn't change, we can reuse existing lut buf */
2396 if (rss_data->rss_lut_size == le16_to_cpu(recv_rl->lut_entries))
2397 goto do_memcpy;
2398
2399 rss_data->rss_lut_size = le16_to_cpu(recv_rl->lut_entries);
2400 kfree(rss_data->rss_lut);
2401
2402 rss_data->rss_lut = kzalloc(lut_buf_size, GFP_KERNEL);
2403 if (!rss_data->rss_lut) {
2404 rss_data->rss_lut_size = 0;
2405 return -ENOMEM;
2406 }
2407
2408do_memcpy:
2409 memcpy(rss_data->rss_lut, recv_rl->lut, rss_data->rss_lut_size);
2410
2411 return 0;
2412}
2413
2414/**
2415 * idpf_send_get_set_rss_key_msg - Send virtchnl get or set rss key message
2416 * @vport: virtual port data structure
2417 * @get: flag to set or get rss look up table
2418 *
2419 * Returns 0 on success, negative on failure
2420 */
2421int idpf_send_get_set_rss_key_msg(struct idpf_vport *vport, bool get)
2422{
2423 struct virtchnl2_rss_key *recv_rk __free(kfree) = NULL;
2424 struct virtchnl2_rss_key *rk __free(kfree) = NULL;
2425 struct idpf_vc_xn_params xn_params = {};
2426 struct idpf_rss_data *rss_data;
2427 ssize_t reply_sz;
2428 int i, buf_size;
2429 u16 key_size;
2430
2431 rss_data =
2432 &vport->adapter->vport_config[vport->idx]->user_config.rss_data;
2433 buf_size = struct_size(rk, key_flex, rss_data->rss_key_size);
2434 rk = kzalloc(buf_size, GFP_KERNEL);
2435 if (!rk)
2436 return -ENOMEM;
2437
2438 rk->vport_id = cpu_to_le32(vport->vport_id);
2439 xn_params.send_buf.iov_base = rk;
2440 xn_params.send_buf.iov_len = buf_size;
2441 xn_params.timeout_ms = IDPF_VC_XN_DEFAULT_TIMEOUT_MSEC;
2442 if (get) {
2443 recv_rk = kzalloc(IDPF_CTLQ_MAX_BUF_LEN, GFP_KERNEL);
2444 if (!recv_rk)
2445 return -ENOMEM;
2446
2447 xn_params.vc_op = VIRTCHNL2_OP_GET_RSS_KEY;
2448 xn_params.recv_buf.iov_base = recv_rk;
2449 xn_params.recv_buf.iov_len = IDPF_CTLQ_MAX_BUF_LEN;
2450 } else {
2451 rk->key_len = cpu_to_le16(rss_data->rss_key_size);
2452 for (i = 0; i < rss_data->rss_key_size; i++)
2453 rk->key_flex[i] = rss_data->rss_key[i];
2454
2455 xn_params.vc_op = VIRTCHNL2_OP_SET_RSS_KEY;
2456 }
2457
2458 reply_sz = idpf_vc_xn_exec(vport->adapter, &xn_params);
2459 if (reply_sz < 0)
2460 return reply_sz;
2461 if (!get)
2462 return 0;
2463 if (reply_sz < sizeof(struct virtchnl2_rss_key))
2464 return -EIO;
2465
2466 key_size = min_t(u16, NETDEV_RSS_KEY_LEN,
2467 le16_to_cpu(recv_rk->key_len));
2468 if (reply_sz < key_size)
2469 return -EIO;
2470
2471 /* key len didn't change, reuse existing buf */
2472 if (rss_data->rss_key_size == key_size)
2473 goto do_memcpy;
2474
2475 rss_data->rss_key_size = key_size;
2476 kfree(rss_data->rss_key);
2477 rss_data->rss_key = kzalloc(key_size, GFP_KERNEL);
2478 if (!rss_data->rss_key) {
2479 rss_data->rss_key_size = 0;
2480 return -ENOMEM;
2481 }
2482
2483do_memcpy:
2484 memcpy(rss_data->rss_key, recv_rk->key_flex, rss_data->rss_key_size);
2485
2486 return 0;
2487}
2488
2489/**
2490 * idpf_fill_ptype_lookup - Fill L3 specific fields in ptype lookup table
2491 * @ptype: ptype lookup table
2492 * @pstate: state machine for ptype lookup table
2493 * @ipv4: ipv4 or ipv6
2494 * @frag: fragmentation allowed
2495 *
2496 */
2497static void idpf_fill_ptype_lookup(struct libeth_rx_pt *ptype,
2498 struct idpf_ptype_state *pstate,
2499 bool ipv4, bool frag)
2500{
2501 if (!pstate->outer_ip || !pstate->outer_frag) {
2502 pstate->outer_ip = true;
2503
2504 if (ipv4)
2505 ptype->outer_ip = LIBETH_RX_PT_OUTER_IPV4;
2506 else
2507 ptype->outer_ip = LIBETH_RX_PT_OUTER_IPV6;
2508
2509 if (frag) {
2510 ptype->outer_frag = LIBETH_RX_PT_FRAG;
2511 pstate->outer_frag = true;
2512 }
2513 } else {
2514 ptype->tunnel_type = LIBETH_RX_PT_TUNNEL_IP_IP;
2515 pstate->tunnel_state = IDPF_PTYPE_TUNNEL_IP;
2516
2517 if (ipv4)
2518 ptype->tunnel_end_prot = LIBETH_RX_PT_TUNNEL_END_IPV4;
2519 else
2520 ptype->tunnel_end_prot = LIBETH_RX_PT_TUNNEL_END_IPV6;
2521
2522 if (frag)
2523 ptype->tunnel_end_frag = LIBETH_RX_PT_FRAG;
2524 }
2525}
2526
2527static void idpf_finalize_ptype_lookup(struct libeth_rx_pt *ptype)
2528{
2529 if (ptype->payload_layer == LIBETH_RX_PT_PAYLOAD_L2 &&
2530 ptype->inner_prot)
2531 ptype->payload_layer = LIBETH_RX_PT_PAYLOAD_L4;
2532 else if (ptype->payload_layer == LIBETH_RX_PT_PAYLOAD_L2 &&
2533 ptype->outer_ip)
2534 ptype->payload_layer = LIBETH_RX_PT_PAYLOAD_L3;
2535 else if (ptype->outer_ip == LIBETH_RX_PT_OUTER_L2)
2536 ptype->payload_layer = LIBETH_RX_PT_PAYLOAD_L2;
2537 else
2538 ptype->payload_layer = LIBETH_RX_PT_PAYLOAD_NONE;
2539
2540 libeth_rx_pt_gen_hash_type(ptype);
2541}
2542
2543/**
2544 * idpf_send_get_rx_ptype_msg - Send virtchnl for ptype info
2545 * @vport: virtual port data structure
2546 *
2547 * Returns 0 on success, negative on failure.
2548 */
2549int idpf_send_get_rx_ptype_msg(struct idpf_vport *vport)
2550{
2551 struct virtchnl2_get_ptype_info *get_ptype_info __free(kfree) = NULL;
2552 struct virtchnl2_get_ptype_info *ptype_info __free(kfree) = NULL;
2553 struct libeth_rx_pt *ptype_lkup __free(kfree) = NULL;
2554 int max_ptype, ptypes_recvd = 0, ptype_offset;
2555 struct idpf_adapter *adapter = vport->adapter;
2556 struct idpf_vc_xn_params xn_params = {};
2557 u16 next_ptype_id = 0;
2558 ssize_t reply_sz;
2559 int i, j, k;
2560
2561 if (vport->rx_ptype_lkup)
2562 return 0;
2563
2564 if (idpf_is_queue_model_split(vport->rxq_model))
2565 max_ptype = IDPF_RX_MAX_PTYPE;
2566 else
2567 max_ptype = IDPF_RX_MAX_BASE_PTYPE;
2568
2569 ptype_lkup = kcalloc(max_ptype, sizeof(*ptype_lkup), GFP_KERNEL);
2570 if (!ptype_lkup)
2571 return -ENOMEM;
2572
2573 get_ptype_info = kzalloc(sizeof(*get_ptype_info), GFP_KERNEL);
2574 if (!get_ptype_info)
2575 return -ENOMEM;
2576
2577 ptype_info = kzalloc(IDPF_CTLQ_MAX_BUF_LEN, GFP_KERNEL);
2578 if (!ptype_info)
2579 return -ENOMEM;
2580
2581 xn_params.vc_op = VIRTCHNL2_OP_GET_PTYPE_INFO;
2582 xn_params.send_buf.iov_base = get_ptype_info;
2583 xn_params.send_buf.iov_len = sizeof(*get_ptype_info);
2584 xn_params.recv_buf.iov_base = ptype_info;
2585 xn_params.recv_buf.iov_len = IDPF_CTLQ_MAX_BUF_LEN;
2586 xn_params.timeout_ms = IDPF_VC_XN_DEFAULT_TIMEOUT_MSEC;
2587
2588 while (next_ptype_id < max_ptype) {
2589 get_ptype_info->start_ptype_id = cpu_to_le16(next_ptype_id);
2590
2591 if ((next_ptype_id + IDPF_RX_MAX_PTYPES_PER_BUF) > max_ptype)
2592 get_ptype_info->num_ptypes =
2593 cpu_to_le16(max_ptype - next_ptype_id);
2594 else
2595 get_ptype_info->num_ptypes =
2596 cpu_to_le16(IDPF_RX_MAX_PTYPES_PER_BUF);
2597
2598 reply_sz = idpf_vc_xn_exec(adapter, &xn_params);
2599 if (reply_sz < 0)
2600 return reply_sz;
2601
2602 ptypes_recvd += le16_to_cpu(ptype_info->num_ptypes);
2603 if (ptypes_recvd > max_ptype)
2604 return -EINVAL;
2605
2606 next_ptype_id = le16_to_cpu(get_ptype_info->start_ptype_id) +
2607 le16_to_cpu(get_ptype_info->num_ptypes);
2608
2609 ptype_offset = IDPF_RX_PTYPE_HDR_SZ;
2610
2611 for (i = 0; i < le16_to_cpu(ptype_info->num_ptypes); i++) {
2612 struct idpf_ptype_state pstate = { };
2613 struct virtchnl2_ptype *ptype;
2614 u16 id;
2615
2616 ptype = (struct virtchnl2_ptype *)
2617 ((u8 *)ptype_info + ptype_offset);
2618
2619 ptype_offset += IDPF_GET_PTYPE_SIZE(ptype);
2620 if (ptype_offset > IDPF_CTLQ_MAX_BUF_LEN)
2621 return -EINVAL;
2622
2623 /* 0xFFFF indicates end of ptypes */
2624 if (le16_to_cpu(ptype->ptype_id_10) ==
2625 IDPF_INVALID_PTYPE_ID)
2626 goto out;
2627
2628 if (idpf_is_queue_model_split(vport->rxq_model))
2629 k = le16_to_cpu(ptype->ptype_id_10);
2630 else
2631 k = ptype->ptype_id_8;
2632
2633 for (j = 0; j < ptype->proto_id_count; j++) {
2634 id = le16_to_cpu(ptype->proto_id[j]);
2635 switch (id) {
2636 case VIRTCHNL2_PROTO_HDR_GRE:
2637 if (pstate.tunnel_state ==
2638 IDPF_PTYPE_TUNNEL_IP) {
2639 ptype_lkup[k].tunnel_type =
2640 LIBETH_RX_PT_TUNNEL_IP_GRENAT;
2641 pstate.tunnel_state |=
2642 IDPF_PTYPE_TUNNEL_IP_GRENAT;
2643 }
2644 break;
2645 case VIRTCHNL2_PROTO_HDR_MAC:
2646 ptype_lkup[k].outer_ip =
2647 LIBETH_RX_PT_OUTER_L2;
2648 if (pstate.tunnel_state ==
2649 IDPF_TUN_IP_GRE) {
2650 ptype_lkup[k].tunnel_type =
2651 LIBETH_RX_PT_TUNNEL_IP_GRENAT_MAC;
2652 pstate.tunnel_state |=
2653 IDPF_PTYPE_TUNNEL_IP_GRENAT_MAC;
2654 }
2655 break;
2656 case VIRTCHNL2_PROTO_HDR_IPV4:
2657 idpf_fill_ptype_lookup(&ptype_lkup[k],
2658 &pstate, true,
2659 false);
2660 break;
2661 case VIRTCHNL2_PROTO_HDR_IPV6:
2662 idpf_fill_ptype_lookup(&ptype_lkup[k],
2663 &pstate, false,
2664 false);
2665 break;
2666 case VIRTCHNL2_PROTO_HDR_IPV4_FRAG:
2667 idpf_fill_ptype_lookup(&ptype_lkup[k],
2668 &pstate, true,
2669 true);
2670 break;
2671 case VIRTCHNL2_PROTO_HDR_IPV6_FRAG:
2672 idpf_fill_ptype_lookup(&ptype_lkup[k],
2673 &pstate, false,
2674 true);
2675 break;
2676 case VIRTCHNL2_PROTO_HDR_UDP:
2677 ptype_lkup[k].inner_prot =
2678 LIBETH_RX_PT_INNER_UDP;
2679 break;
2680 case VIRTCHNL2_PROTO_HDR_TCP:
2681 ptype_lkup[k].inner_prot =
2682 LIBETH_RX_PT_INNER_TCP;
2683 break;
2684 case VIRTCHNL2_PROTO_HDR_SCTP:
2685 ptype_lkup[k].inner_prot =
2686 LIBETH_RX_PT_INNER_SCTP;
2687 break;
2688 case VIRTCHNL2_PROTO_HDR_ICMP:
2689 ptype_lkup[k].inner_prot =
2690 LIBETH_RX_PT_INNER_ICMP;
2691 break;
2692 case VIRTCHNL2_PROTO_HDR_PAY:
2693 ptype_lkup[k].payload_layer =
2694 LIBETH_RX_PT_PAYLOAD_L2;
2695 break;
2696 case VIRTCHNL2_PROTO_HDR_ICMPV6:
2697 case VIRTCHNL2_PROTO_HDR_IPV6_EH:
2698 case VIRTCHNL2_PROTO_HDR_PRE_MAC:
2699 case VIRTCHNL2_PROTO_HDR_POST_MAC:
2700 case VIRTCHNL2_PROTO_HDR_ETHERTYPE:
2701 case VIRTCHNL2_PROTO_HDR_SVLAN:
2702 case VIRTCHNL2_PROTO_HDR_CVLAN:
2703 case VIRTCHNL2_PROTO_HDR_MPLS:
2704 case VIRTCHNL2_PROTO_HDR_MMPLS:
2705 case VIRTCHNL2_PROTO_HDR_PTP:
2706 case VIRTCHNL2_PROTO_HDR_CTRL:
2707 case VIRTCHNL2_PROTO_HDR_LLDP:
2708 case VIRTCHNL2_PROTO_HDR_ARP:
2709 case VIRTCHNL2_PROTO_HDR_ECP:
2710 case VIRTCHNL2_PROTO_HDR_EAPOL:
2711 case VIRTCHNL2_PROTO_HDR_PPPOD:
2712 case VIRTCHNL2_PROTO_HDR_PPPOE:
2713 case VIRTCHNL2_PROTO_HDR_IGMP:
2714 case VIRTCHNL2_PROTO_HDR_AH:
2715 case VIRTCHNL2_PROTO_HDR_ESP:
2716 case VIRTCHNL2_PROTO_HDR_IKE:
2717 case VIRTCHNL2_PROTO_HDR_NATT_KEEP:
2718 case VIRTCHNL2_PROTO_HDR_L2TPV2:
2719 case VIRTCHNL2_PROTO_HDR_L2TPV2_CONTROL:
2720 case VIRTCHNL2_PROTO_HDR_L2TPV3:
2721 case VIRTCHNL2_PROTO_HDR_GTP:
2722 case VIRTCHNL2_PROTO_HDR_GTP_EH:
2723 case VIRTCHNL2_PROTO_HDR_GTPCV2:
2724 case VIRTCHNL2_PROTO_HDR_GTPC_TEID:
2725 case VIRTCHNL2_PROTO_HDR_GTPU:
2726 case VIRTCHNL2_PROTO_HDR_GTPU_UL:
2727 case VIRTCHNL2_PROTO_HDR_GTPU_DL:
2728 case VIRTCHNL2_PROTO_HDR_ECPRI:
2729 case VIRTCHNL2_PROTO_HDR_VRRP:
2730 case VIRTCHNL2_PROTO_HDR_OSPF:
2731 case VIRTCHNL2_PROTO_HDR_TUN:
2732 case VIRTCHNL2_PROTO_HDR_NVGRE:
2733 case VIRTCHNL2_PROTO_HDR_VXLAN:
2734 case VIRTCHNL2_PROTO_HDR_VXLAN_GPE:
2735 case VIRTCHNL2_PROTO_HDR_GENEVE:
2736 case VIRTCHNL2_PROTO_HDR_NSH:
2737 case VIRTCHNL2_PROTO_HDR_QUIC:
2738 case VIRTCHNL2_PROTO_HDR_PFCP:
2739 case VIRTCHNL2_PROTO_HDR_PFCP_NODE:
2740 case VIRTCHNL2_PROTO_HDR_PFCP_SESSION:
2741 case VIRTCHNL2_PROTO_HDR_RTP:
2742 case VIRTCHNL2_PROTO_HDR_NO_PROTO:
2743 break;
2744 default:
2745 break;
2746 }
2747 }
2748
2749 idpf_finalize_ptype_lookup(&ptype_lkup[k]);
2750 }
2751 }
2752
2753out:
2754 vport->rx_ptype_lkup = no_free_ptr(ptype_lkup);
2755
2756 return 0;
2757}
2758
2759/**
2760 * idpf_send_ena_dis_loopback_msg - Send virtchnl enable/disable loopback
2761 * message
2762 * @vport: virtual port data structure
2763 *
2764 * Returns 0 on success, negative on failure.
2765 */
2766int idpf_send_ena_dis_loopback_msg(struct idpf_vport *vport)
2767{
2768 struct idpf_vc_xn_params xn_params = {};
2769 struct virtchnl2_loopback loopback;
2770 ssize_t reply_sz;
2771
2772 loopback.vport_id = cpu_to_le32(vport->vport_id);
2773 loopback.enable = idpf_is_feature_ena(vport, NETIF_F_LOOPBACK);
2774
2775 xn_params.vc_op = VIRTCHNL2_OP_LOOPBACK;
2776 xn_params.timeout_ms = IDPF_VC_XN_DEFAULT_TIMEOUT_MSEC;
2777 xn_params.send_buf.iov_base = &loopback;
2778 xn_params.send_buf.iov_len = sizeof(loopback);
2779 reply_sz = idpf_vc_xn_exec(vport->adapter, &xn_params);
2780
2781 return reply_sz < 0 ? reply_sz : 0;
2782}
2783
2784/**
2785 * idpf_find_ctlq - Given a type and id, find ctlq info
2786 * @hw: hardware struct
2787 * @type: type of ctrlq to find
2788 * @id: ctlq id to find
2789 *
2790 * Returns pointer to found ctlq info struct, NULL otherwise.
2791 */
2792static struct idpf_ctlq_info *idpf_find_ctlq(struct idpf_hw *hw,
2793 enum idpf_ctlq_type type, int id)
2794{
2795 struct idpf_ctlq_info *cq, *tmp;
2796
2797 list_for_each_entry_safe(cq, tmp, &hw->cq_list_head, cq_list)
2798 if (cq->q_id == id && cq->cq_type == type)
2799 return cq;
2800
2801 return NULL;
2802}
2803
2804/**
2805 * idpf_init_dflt_mbx - Setup default mailbox parameters and make request
2806 * @adapter: adapter info struct
2807 *
2808 * Returns 0 on success, negative otherwise
2809 */
2810int idpf_init_dflt_mbx(struct idpf_adapter *adapter)
2811{
2812 struct idpf_ctlq_create_info ctlq_info[] = {
2813 {
2814 .type = IDPF_CTLQ_TYPE_MAILBOX_TX,
2815 .id = IDPF_DFLT_MBX_ID,
2816 .len = IDPF_DFLT_MBX_Q_LEN,
2817 .buf_size = IDPF_CTLQ_MAX_BUF_LEN
2818 },
2819 {
2820 .type = IDPF_CTLQ_TYPE_MAILBOX_RX,
2821 .id = IDPF_DFLT_MBX_ID,
2822 .len = IDPF_DFLT_MBX_Q_LEN,
2823 .buf_size = IDPF_CTLQ_MAX_BUF_LEN
2824 }
2825 };
2826 struct idpf_hw *hw = &adapter->hw;
2827 int err;
2828
2829 adapter->dev_ops.reg_ops.ctlq_reg_init(ctlq_info);
2830
2831 err = idpf_ctlq_init(hw, IDPF_NUM_DFLT_MBX_Q, ctlq_info);
2832 if (err)
2833 return err;
2834
2835 hw->asq = idpf_find_ctlq(hw, IDPF_CTLQ_TYPE_MAILBOX_TX,
2836 IDPF_DFLT_MBX_ID);
2837 hw->arq = idpf_find_ctlq(hw, IDPF_CTLQ_TYPE_MAILBOX_RX,
2838 IDPF_DFLT_MBX_ID);
2839
2840 if (!hw->asq || !hw->arq) {
2841 idpf_ctlq_deinit(hw);
2842
2843 return -ENOENT;
2844 }
2845
2846 adapter->state = __IDPF_VER_CHECK;
2847
2848 return 0;
2849}
2850
2851/**
2852 * idpf_deinit_dflt_mbx - Free up ctlqs setup
2853 * @adapter: Driver specific private data structure
2854 */
2855void idpf_deinit_dflt_mbx(struct idpf_adapter *adapter)
2856{
2857 if (adapter->hw.arq && adapter->hw.asq) {
2858 idpf_mb_clean(adapter);
2859 idpf_ctlq_deinit(&adapter->hw);
2860 }
2861 adapter->hw.arq = NULL;
2862 adapter->hw.asq = NULL;
2863}
2864
2865/**
2866 * idpf_vport_params_buf_rel - Release memory for MailBox resources
2867 * @adapter: Driver specific private data structure
2868 *
2869 * Will release memory to hold the vport parameters received on MailBox
2870 */
2871static void idpf_vport_params_buf_rel(struct idpf_adapter *adapter)
2872{
2873 kfree(adapter->vport_params_recvd);
2874 adapter->vport_params_recvd = NULL;
2875 kfree(adapter->vport_params_reqd);
2876 adapter->vport_params_reqd = NULL;
2877 kfree(adapter->vport_ids);
2878 adapter->vport_ids = NULL;
2879}
2880
2881/**
2882 * idpf_vport_params_buf_alloc - Allocate memory for MailBox resources
2883 * @adapter: Driver specific private data structure
2884 *
2885 * Will alloc memory to hold the vport parameters received on MailBox
2886 */
2887static int idpf_vport_params_buf_alloc(struct idpf_adapter *adapter)
2888{
2889 u16 num_max_vports = idpf_get_max_vports(adapter);
2890
2891 adapter->vport_params_reqd = kcalloc(num_max_vports,
2892 sizeof(*adapter->vport_params_reqd),
2893 GFP_KERNEL);
2894 if (!adapter->vport_params_reqd)
2895 return -ENOMEM;
2896
2897 adapter->vport_params_recvd = kcalloc(num_max_vports,
2898 sizeof(*adapter->vport_params_recvd),
2899 GFP_KERNEL);
2900 if (!adapter->vport_params_recvd)
2901 goto err_mem;
2902
2903 adapter->vport_ids = kcalloc(num_max_vports, sizeof(u32), GFP_KERNEL);
2904 if (!adapter->vport_ids)
2905 goto err_mem;
2906
2907 if (adapter->vport_config)
2908 return 0;
2909
2910 adapter->vport_config = kcalloc(num_max_vports,
2911 sizeof(*adapter->vport_config),
2912 GFP_KERNEL);
2913 if (!adapter->vport_config)
2914 goto err_mem;
2915
2916 return 0;
2917
2918err_mem:
2919 idpf_vport_params_buf_rel(adapter);
2920
2921 return -ENOMEM;
2922}
2923
2924/**
2925 * idpf_vc_core_init - Initialize state machine and get driver specific
2926 * resources
2927 * @adapter: Driver specific private structure
2928 *
2929 * This function will initialize the state machine and request all necessary
2930 * resources required by the device driver. Once the state machine is
2931 * initialized, allocate memory to store vport specific information and also
2932 * requests required interrupts.
2933 *
2934 * Returns 0 on success, -EAGAIN function will get called again,
2935 * otherwise negative on failure.
2936 */
2937int idpf_vc_core_init(struct idpf_adapter *adapter)
2938{
2939 int task_delay = 30;
2940 u16 num_max_vports;
2941 int err = 0;
2942
2943 if (!adapter->vcxn_mngr) {
2944 adapter->vcxn_mngr = kzalloc(sizeof(*adapter->vcxn_mngr), GFP_KERNEL);
2945 if (!adapter->vcxn_mngr) {
2946 err = -ENOMEM;
2947 goto init_failed;
2948 }
2949 }
2950 idpf_vc_xn_init(adapter->vcxn_mngr);
2951
2952 while (adapter->state != __IDPF_INIT_SW) {
2953 switch (adapter->state) {
2954 case __IDPF_VER_CHECK:
2955 err = idpf_send_ver_msg(adapter);
2956 switch (err) {
2957 case 0:
2958 /* success, move state machine forward */
2959 adapter->state = __IDPF_GET_CAPS;
2960 fallthrough;
2961 case -EAGAIN:
2962 goto restart;
2963 default:
2964 /* Something bad happened, try again but only a
2965 * few times.
2966 */
2967 goto init_failed;
2968 }
2969 case __IDPF_GET_CAPS:
2970 err = idpf_send_get_caps_msg(adapter);
2971 if (err)
2972 goto init_failed;
2973 adapter->state = __IDPF_INIT_SW;
2974 break;
2975 default:
2976 dev_err(&adapter->pdev->dev, "Device is in bad state: %d\n",
2977 adapter->state);
2978 err = -EINVAL;
2979 goto init_failed;
2980 }
2981 break;
2982restart:
2983 /* Give enough time before proceeding further with
2984 * state machine
2985 */
2986 msleep(task_delay);
2987 }
2988
2989 pci_sriov_set_totalvfs(adapter->pdev, idpf_get_max_vfs(adapter));
2990 num_max_vports = idpf_get_max_vports(adapter);
2991 adapter->max_vports = num_max_vports;
2992 adapter->vports = kcalloc(num_max_vports, sizeof(*adapter->vports),
2993 GFP_KERNEL);
2994 if (!adapter->vports)
2995 return -ENOMEM;
2996
2997 if (!adapter->netdevs) {
2998 adapter->netdevs = kcalloc(num_max_vports,
2999 sizeof(struct net_device *),
3000 GFP_KERNEL);
3001 if (!adapter->netdevs) {
3002 err = -ENOMEM;
3003 goto err_netdev_alloc;
3004 }
3005 }
3006
3007 err = idpf_vport_params_buf_alloc(adapter);
3008 if (err) {
3009 dev_err(&adapter->pdev->dev, "Failed to alloc vport params buffer: %d\n",
3010 err);
3011 goto err_netdev_alloc;
3012 }
3013
3014 /* Start the mailbox task before requesting vectors. This will ensure
3015 * vector information response from mailbox is handled
3016 */
3017 queue_delayed_work(adapter->mbx_wq, &adapter->mbx_task, 0);
3018
3019 queue_delayed_work(adapter->serv_wq, &adapter->serv_task,
3020 msecs_to_jiffies(5 * (adapter->pdev->devfn & 0x07)));
3021
3022 err = idpf_intr_req(adapter);
3023 if (err) {
3024 dev_err(&adapter->pdev->dev, "failed to enable interrupt vectors: %d\n",
3025 err);
3026 goto err_intr_req;
3027 }
3028
3029 idpf_init_avail_queues(adapter);
3030
3031 /* Skew the delay for init tasks for each function based on fn number
3032 * to prevent every function from making the same call simultaneously.
3033 */
3034 queue_delayed_work(adapter->init_wq, &adapter->init_task,
3035 msecs_to_jiffies(5 * (adapter->pdev->devfn & 0x07)));
3036
3037 set_bit(IDPF_VC_CORE_INIT, adapter->flags);
3038
3039 return 0;
3040
3041err_intr_req:
3042 cancel_delayed_work_sync(&adapter->serv_task);
3043 cancel_delayed_work_sync(&adapter->mbx_task);
3044 idpf_vport_params_buf_rel(adapter);
3045err_netdev_alloc:
3046 kfree(adapter->vports);
3047 adapter->vports = NULL;
3048 return err;
3049
3050init_failed:
3051 /* Don't retry if we're trying to go down, just bail. */
3052 if (test_bit(IDPF_REMOVE_IN_PROG, adapter->flags))
3053 return err;
3054
3055 if (++adapter->mb_wait_count > IDPF_MB_MAX_ERR) {
3056 dev_err(&adapter->pdev->dev, "Failed to establish mailbox communications with hardware\n");
3057
3058 return -EFAULT;
3059 }
3060 /* If it reached here, it is possible that mailbox queue initialization
3061 * register writes might not have taken effect. Retry to initialize
3062 * the mailbox again
3063 */
3064 adapter->state = __IDPF_VER_CHECK;
3065 if (adapter->vcxn_mngr)
3066 idpf_vc_xn_shutdown(adapter->vcxn_mngr);
3067 set_bit(IDPF_HR_DRV_LOAD, adapter->flags);
3068 queue_delayed_work(adapter->vc_event_wq, &adapter->vc_event_task,
3069 msecs_to_jiffies(task_delay));
3070
3071 return -EAGAIN;
3072}
3073
3074/**
3075 * idpf_vc_core_deinit - Device deinit routine
3076 * @adapter: Driver specific private structure
3077 *
3078 */
3079void idpf_vc_core_deinit(struct idpf_adapter *adapter)
3080{
3081 bool remove_in_prog;
3082
3083 if (!test_bit(IDPF_VC_CORE_INIT, adapter->flags))
3084 return;
3085
3086 /* Avoid transaction timeouts when called during reset */
3087 remove_in_prog = test_bit(IDPF_REMOVE_IN_PROG, adapter->flags);
3088 if (!remove_in_prog)
3089 idpf_vc_xn_shutdown(adapter->vcxn_mngr);
3090
3091 idpf_deinit_task(adapter);
3092 idpf_intr_rel(adapter);
3093
3094 if (remove_in_prog)
3095 idpf_vc_xn_shutdown(adapter->vcxn_mngr);
3096
3097 cancel_delayed_work_sync(&adapter->serv_task);
3098 cancel_delayed_work_sync(&adapter->mbx_task);
3099
3100 idpf_vport_params_buf_rel(adapter);
3101
3102 kfree(adapter->vports);
3103 adapter->vports = NULL;
3104
3105 clear_bit(IDPF_VC_CORE_INIT, adapter->flags);
3106}
3107
3108/**
3109 * idpf_vport_alloc_vec_indexes - Get relative vector indexes
3110 * @vport: virtual port data struct
3111 *
3112 * This function requests the vector information required for the vport and
3113 * stores the vector indexes received from the 'global vector distribution'
3114 * in the vport's queue vectors array.
3115 *
3116 * Return 0 on success, error on failure
3117 */
3118int idpf_vport_alloc_vec_indexes(struct idpf_vport *vport)
3119{
3120 struct idpf_vector_info vec_info;
3121 int num_alloc_vecs;
3122
3123 vec_info.num_curr_vecs = vport->num_q_vectors;
3124 vec_info.num_req_vecs = max(vport->num_txq, vport->num_rxq);
3125 vec_info.default_vport = vport->default_vport;
3126 vec_info.index = vport->idx;
3127
3128 num_alloc_vecs = idpf_req_rel_vector_indexes(vport->adapter,
3129 vport->q_vector_idxs,
3130 &vec_info);
3131 if (num_alloc_vecs <= 0) {
3132 dev_err(&vport->adapter->pdev->dev, "Vector distribution failed: %d\n",
3133 num_alloc_vecs);
3134 return -EINVAL;
3135 }
3136
3137 vport->num_q_vectors = num_alloc_vecs;
3138
3139 return 0;
3140}
3141
3142/**
3143 * idpf_vport_init - Initialize virtual port
3144 * @vport: virtual port to be initialized
3145 * @max_q: vport max queue info
3146 *
3147 * Will initialize vport with the info received through MB earlier
3148 */
3149void idpf_vport_init(struct idpf_vport *vport, struct idpf_vport_max_q *max_q)
3150{
3151 struct idpf_adapter *adapter = vport->adapter;
3152 struct virtchnl2_create_vport *vport_msg;
3153 struct idpf_vport_config *vport_config;
3154 u16 tx_itr[] = {2, 8, 64, 128, 256};
3155 u16 rx_itr[] = {2, 8, 32, 96, 128};
3156 struct idpf_rss_data *rss_data;
3157 u16 idx = vport->idx;
3158
3159 vport_config = adapter->vport_config[idx];
3160 rss_data = &vport_config->user_config.rss_data;
3161 vport_msg = adapter->vport_params_recvd[idx];
3162
3163 vport_config->max_q.max_txq = max_q->max_txq;
3164 vport_config->max_q.max_rxq = max_q->max_rxq;
3165 vport_config->max_q.max_complq = max_q->max_complq;
3166 vport_config->max_q.max_bufq = max_q->max_bufq;
3167
3168 vport->txq_model = le16_to_cpu(vport_msg->txq_model);
3169 vport->rxq_model = le16_to_cpu(vport_msg->rxq_model);
3170 vport->vport_type = le16_to_cpu(vport_msg->vport_type);
3171 vport->vport_id = le32_to_cpu(vport_msg->vport_id);
3172
3173 rss_data->rss_key_size = min_t(u16, NETDEV_RSS_KEY_LEN,
3174 le16_to_cpu(vport_msg->rss_key_size));
3175 rss_data->rss_lut_size = le16_to_cpu(vport_msg->rss_lut_size);
3176
3177 ether_addr_copy(vport->default_mac_addr, vport_msg->default_mac_addr);
3178 vport->max_mtu = le16_to_cpu(vport_msg->max_mtu) - LIBETH_RX_LL_LEN;
3179
3180 /* Initialize Tx and Rx profiles for Dynamic Interrupt Moderation */
3181 memcpy(vport->rx_itr_profile, rx_itr, IDPF_DIM_PROFILE_SLOTS);
3182 memcpy(vport->tx_itr_profile, tx_itr, IDPF_DIM_PROFILE_SLOTS);
3183
3184 idpf_vport_set_hsplit(vport, ETHTOOL_TCP_DATA_SPLIT_ENABLED);
3185
3186 idpf_vport_init_num_qs(vport, vport_msg);
3187 idpf_vport_calc_num_q_desc(vport);
3188 idpf_vport_calc_num_q_groups(vport);
3189 idpf_vport_alloc_vec_indexes(vport);
3190
3191 vport->crc_enable = adapter->crc_enable;
3192}
3193
3194/**
3195 * idpf_get_vec_ids - Initialize vector id from Mailbox parameters
3196 * @adapter: adapter structure to get the mailbox vector id
3197 * @vecids: Array of vector ids
3198 * @num_vecids: number of vector ids
3199 * @chunks: vector ids received over mailbox
3200 *
3201 * Will initialize the mailbox vector id which is received from the
3202 * get capabilities and data queue vector ids with ids received as
3203 * mailbox parameters.
3204 * Returns number of ids filled
3205 */
3206int idpf_get_vec_ids(struct idpf_adapter *adapter,
3207 u16 *vecids, int num_vecids,
3208 struct virtchnl2_vector_chunks *chunks)
3209{
3210 u16 num_chunks = le16_to_cpu(chunks->num_vchunks);
3211 int num_vecid_filled = 0;
3212 int i, j;
3213
3214 vecids[num_vecid_filled] = adapter->mb_vector.v_idx;
3215 num_vecid_filled++;
3216
3217 for (j = 0; j < num_chunks; j++) {
3218 struct virtchnl2_vector_chunk *chunk;
3219 u16 start_vecid, num_vec;
3220
3221 chunk = &chunks->vchunks[j];
3222 num_vec = le16_to_cpu(chunk->num_vectors);
3223 start_vecid = le16_to_cpu(chunk->start_vector_id);
3224
3225 for (i = 0; i < num_vec; i++) {
3226 if ((num_vecid_filled + i) < num_vecids) {
3227 vecids[num_vecid_filled + i] = start_vecid;
3228 start_vecid++;
3229 } else {
3230 break;
3231 }
3232 }
3233 num_vecid_filled = num_vecid_filled + i;
3234 }
3235
3236 return num_vecid_filled;
3237}
3238
3239/**
3240 * idpf_vport_get_queue_ids - Initialize queue id from Mailbox parameters
3241 * @qids: Array of queue ids
3242 * @num_qids: number of queue ids
3243 * @q_type: queue model
3244 * @chunks: queue ids received over mailbox
3245 *
3246 * Will initialize all queue ids with ids received as mailbox parameters
3247 * Returns number of ids filled
3248 */
3249static int idpf_vport_get_queue_ids(u32 *qids, int num_qids, u16 q_type,
3250 struct virtchnl2_queue_reg_chunks *chunks)
3251{
3252 u16 num_chunks = le16_to_cpu(chunks->num_chunks);
3253 u32 num_q_id_filled = 0, i;
3254 u32 start_q_id, num_q;
3255
3256 while (num_chunks--) {
3257 struct virtchnl2_queue_reg_chunk *chunk;
3258
3259 chunk = &chunks->chunks[num_chunks];
3260 if (le32_to_cpu(chunk->type) != q_type)
3261 continue;
3262
3263 num_q = le32_to_cpu(chunk->num_queues);
3264 start_q_id = le32_to_cpu(chunk->start_queue_id);
3265
3266 for (i = 0; i < num_q; i++) {
3267 if ((num_q_id_filled + i) < num_qids) {
3268 qids[num_q_id_filled + i] = start_q_id;
3269 start_q_id++;
3270 } else {
3271 break;
3272 }
3273 }
3274 num_q_id_filled = num_q_id_filled + i;
3275 }
3276
3277 return num_q_id_filled;
3278}
3279
3280/**
3281 * __idpf_vport_queue_ids_init - Initialize queue ids from Mailbox parameters
3282 * @vport: virtual port for which the queues ids are initialized
3283 * @qids: queue ids
3284 * @num_qids: number of queue ids
3285 * @q_type: type of queue
3286 *
3287 * Will initialize all queue ids with ids received as mailbox
3288 * parameters. Returns number of queue ids initialized.
3289 */
3290static int __idpf_vport_queue_ids_init(struct idpf_vport *vport,
3291 const u32 *qids,
3292 int num_qids,
3293 u32 q_type)
3294{
3295 int i, j, k = 0;
3296
3297 switch (q_type) {
3298 case VIRTCHNL2_QUEUE_TYPE_TX:
3299 for (i = 0; i < vport->num_txq_grp; i++) {
3300 struct idpf_txq_group *tx_qgrp = &vport->txq_grps[i];
3301
3302 for (j = 0; j < tx_qgrp->num_txq && k < num_qids; j++, k++)
3303 tx_qgrp->txqs[j]->q_id = qids[k];
3304 }
3305 break;
3306 case VIRTCHNL2_QUEUE_TYPE_RX:
3307 for (i = 0; i < vport->num_rxq_grp; i++) {
3308 struct idpf_rxq_group *rx_qgrp = &vport->rxq_grps[i];
3309 u16 num_rxq;
3310
3311 if (idpf_is_queue_model_split(vport->rxq_model))
3312 num_rxq = rx_qgrp->splitq.num_rxq_sets;
3313 else
3314 num_rxq = rx_qgrp->singleq.num_rxq;
3315
3316 for (j = 0; j < num_rxq && k < num_qids; j++, k++) {
3317 struct idpf_rx_queue *q;
3318
3319 if (idpf_is_queue_model_split(vport->rxq_model))
3320 q = &rx_qgrp->splitq.rxq_sets[j]->rxq;
3321 else
3322 q = rx_qgrp->singleq.rxqs[j];
3323 q->q_id = qids[k];
3324 }
3325 }
3326 break;
3327 case VIRTCHNL2_QUEUE_TYPE_TX_COMPLETION:
3328 for (i = 0; i < vport->num_txq_grp && k < num_qids; i++, k++) {
3329 struct idpf_txq_group *tx_qgrp = &vport->txq_grps[i];
3330
3331 tx_qgrp->complq->q_id = qids[k];
3332 }
3333 break;
3334 case VIRTCHNL2_QUEUE_TYPE_RX_BUFFER:
3335 for (i = 0; i < vport->num_rxq_grp; i++) {
3336 struct idpf_rxq_group *rx_qgrp = &vport->rxq_grps[i];
3337 u8 num_bufqs = vport->num_bufqs_per_qgrp;
3338
3339 for (j = 0; j < num_bufqs && k < num_qids; j++, k++) {
3340 struct idpf_buf_queue *q;
3341
3342 q = &rx_qgrp->splitq.bufq_sets[j].bufq;
3343 q->q_id = qids[k];
3344 }
3345 }
3346 break;
3347 default:
3348 break;
3349 }
3350
3351 return k;
3352}
3353
3354/**
3355 * idpf_vport_queue_ids_init - Initialize queue ids from Mailbox parameters
3356 * @vport: virtual port for which the queues ids are initialized
3357 *
3358 * Will initialize all queue ids with ids received as mailbox parameters.
3359 * Returns 0 on success, negative if all the queues are not initialized.
3360 */
3361int idpf_vport_queue_ids_init(struct idpf_vport *vport)
3362{
3363 struct virtchnl2_create_vport *vport_params;
3364 struct virtchnl2_queue_reg_chunks *chunks;
3365 struct idpf_vport_config *vport_config;
3366 u16 vport_idx = vport->idx;
3367 int num_ids, err = 0;
3368 u16 q_type;
3369 u32 *qids;
3370
3371 vport_config = vport->adapter->vport_config[vport_idx];
3372 if (vport_config->req_qs_chunks) {
3373 struct virtchnl2_add_queues *vc_aq =
3374 (struct virtchnl2_add_queues *)vport_config->req_qs_chunks;
3375 chunks = &vc_aq->chunks;
3376 } else {
3377 vport_params = vport->adapter->vport_params_recvd[vport_idx];
3378 chunks = &vport_params->chunks;
3379 }
3380
3381 qids = kcalloc(IDPF_MAX_QIDS, sizeof(u32), GFP_KERNEL);
3382 if (!qids)
3383 return -ENOMEM;
3384
3385 num_ids = idpf_vport_get_queue_ids(qids, IDPF_MAX_QIDS,
3386 VIRTCHNL2_QUEUE_TYPE_TX,
3387 chunks);
3388 if (num_ids < vport->num_txq) {
3389 err = -EINVAL;
3390 goto mem_rel;
3391 }
3392 num_ids = __idpf_vport_queue_ids_init(vport, qids, num_ids,
3393 VIRTCHNL2_QUEUE_TYPE_TX);
3394 if (num_ids < vport->num_txq) {
3395 err = -EINVAL;
3396 goto mem_rel;
3397 }
3398
3399 num_ids = idpf_vport_get_queue_ids(qids, IDPF_MAX_QIDS,
3400 VIRTCHNL2_QUEUE_TYPE_RX,
3401 chunks);
3402 if (num_ids < vport->num_rxq) {
3403 err = -EINVAL;
3404 goto mem_rel;
3405 }
3406 num_ids = __idpf_vport_queue_ids_init(vport, qids, num_ids,
3407 VIRTCHNL2_QUEUE_TYPE_RX);
3408 if (num_ids < vport->num_rxq) {
3409 err = -EINVAL;
3410 goto mem_rel;
3411 }
3412
3413 if (!idpf_is_queue_model_split(vport->txq_model))
3414 goto check_rxq;
3415
3416 q_type = VIRTCHNL2_QUEUE_TYPE_TX_COMPLETION;
3417 num_ids = idpf_vport_get_queue_ids(qids, IDPF_MAX_QIDS, q_type, chunks);
3418 if (num_ids < vport->num_complq) {
3419 err = -EINVAL;
3420 goto mem_rel;
3421 }
3422 num_ids = __idpf_vport_queue_ids_init(vport, qids, num_ids, q_type);
3423 if (num_ids < vport->num_complq) {
3424 err = -EINVAL;
3425 goto mem_rel;
3426 }
3427
3428check_rxq:
3429 if (!idpf_is_queue_model_split(vport->rxq_model))
3430 goto mem_rel;
3431
3432 q_type = VIRTCHNL2_QUEUE_TYPE_RX_BUFFER;
3433 num_ids = idpf_vport_get_queue_ids(qids, IDPF_MAX_QIDS, q_type, chunks);
3434 if (num_ids < vport->num_bufq) {
3435 err = -EINVAL;
3436 goto mem_rel;
3437 }
3438 num_ids = __idpf_vport_queue_ids_init(vport, qids, num_ids, q_type);
3439 if (num_ids < vport->num_bufq)
3440 err = -EINVAL;
3441
3442mem_rel:
3443 kfree(qids);
3444
3445 return err;
3446}
3447
3448/**
3449 * idpf_vport_adjust_qs - Adjust to new requested queues
3450 * @vport: virtual port data struct
3451 *
3452 * Renegotiate queues. Returns 0 on success, negative on failure.
3453 */
3454int idpf_vport_adjust_qs(struct idpf_vport *vport)
3455{
3456 struct virtchnl2_create_vport vport_msg;
3457 int err;
3458
3459 vport_msg.txq_model = cpu_to_le16(vport->txq_model);
3460 vport_msg.rxq_model = cpu_to_le16(vport->rxq_model);
3461 err = idpf_vport_calc_total_qs(vport->adapter, vport->idx, &vport_msg,
3462 NULL);
3463 if (err)
3464 return err;
3465
3466 idpf_vport_init_num_qs(vport, &vport_msg);
3467 idpf_vport_calc_num_q_groups(vport);
3468
3469 return 0;
3470}
3471
3472/**
3473 * idpf_is_capability_ena - Default implementation of capability checking
3474 * @adapter: Private data struct
3475 * @all: all or one flag
3476 * @field: caps field to check for flags
3477 * @flag: flag to check
3478 *
3479 * Return true if all capabilities are supported, false otherwise
3480 */
3481bool idpf_is_capability_ena(struct idpf_adapter *adapter, bool all,
3482 enum idpf_cap_field field, u64 flag)
3483{
3484 u8 *caps = (u8 *)&adapter->caps;
3485 u32 *cap_field;
3486
3487 if (!caps)
3488 return false;
3489
3490 if (field == IDPF_BASE_CAPS)
3491 return false;
3492
3493 cap_field = (u32 *)(caps + field);
3494
3495 if (all)
3496 return (*cap_field & flag) == flag;
3497 else
3498 return !!(*cap_field & flag);
3499}
3500
3501/**
3502 * idpf_get_vport_id: Get vport id
3503 * @vport: virtual port structure
3504 *
3505 * Return vport id from the adapter persistent data
3506 */
3507u32 idpf_get_vport_id(struct idpf_vport *vport)
3508{
3509 struct virtchnl2_create_vport *vport_msg;
3510
3511 vport_msg = vport->adapter->vport_params_recvd[vport->idx];
3512
3513 return le32_to_cpu(vport_msg->vport_id);
3514}
3515
3516/**
3517 * idpf_mac_filter_async_handler - Async callback for mac filters
3518 * @adapter: private data struct
3519 * @xn: transaction for message
3520 * @ctlq_msg: received message
3521 *
3522 * In some scenarios driver can't sleep and wait for a reply (e.g.: stack is
3523 * holding rtnl_lock) when adding a new mac filter. It puts us in a difficult
3524 * situation to deal with errors returned on the reply. The best we can
3525 * ultimately do is remove it from our list of mac filters and report the
3526 * error.
3527 */
3528static int idpf_mac_filter_async_handler(struct idpf_adapter *adapter,
3529 struct idpf_vc_xn *xn,
3530 const struct idpf_ctlq_msg *ctlq_msg)
3531{
3532 struct virtchnl2_mac_addr_list *ma_list;
3533 struct idpf_vport_config *vport_config;
3534 struct virtchnl2_mac_addr *mac_addr;
3535 struct idpf_mac_filter *f, *tmp;
3536 struct list_head *ma_list_head;
3537 struct idpf_vport *vport;
3538 u16 num_entries;
3539 int i;
3540
3541 /* if success we're done, we're only here if something bad happened */
3542 if (!ctlq_msg->cookie.mbx.chnl_retval)
3543 return 0;
3544
3545 /* make sure at least struct is there */
3546 if (xn->reply_sz < sizeof(*ma_list))
3547 goto invalid_payload;
3548
3549 ma_list = ctlq_msg->ctx.indirect.payload->va;
3550 mac_addr = ma_list->mac_addr_list;
3551 num_entries = le16_to_cpu(ma_list->num_mac_addr);
3552 /* we should have received a buffer at least this big */
3553 if (xn->reply_sz < struct_size(ma_list, mac_addr_list, num_entries))
3554 goto invalid_payload;
3555
3556 vport = idpf_vid_to_vport(adapter, le32_to_cpu(ma_list->vport_id));
3557 if (!vport)
3558 goto invalid_payload;
3559
3560 vport_config = adapter->vport_config[le32_to_cpu(ma_list->vport_id)];
3561 ma_list_head = &vport_config->user_config.mac_filter_list;
3562
3563 /* We can't do much to reconcile bad filters at this point, however we
3564 * should at least remove them from our list one way or the other so we
3565 * have some idea what good filters we have.
3566 */
3567 spin_lock_bh(&vport_config->mac_filter_list_lock);
3568 list_for_each_entry_safe(f, tmp, ma_list_head, list)
3569 for (i = 0; i < num_entries; i++)
3570 if (ether_addr_equal(mac_addr[i].addr, f->macaddr))
3571 list_del(&f->list);
3572 spin_unlock_bh(&vport_config->mac_filter_list_lock);
3573 dev_err_ratelimited(&adapter->pdev->dev, "Received error sending MAC filter request (op %d)\n",
3574 xn->vc_op);
3575
3576 return 0;
3577
3578invalid_payload:
3579 dev_err_ratelimited(&adapter->pdev->dev, "Received invalid MAC filter payload (op %d) (len %zd)\n",
3580 xn->vc_op, xn->reply_sz);
3581
3582 return -EINVAL;
3583}
3584
3585/**
3586 * idpf_add_del_mac_filters - Add/del mac filters
3587 * @vport: Virtual port data structure
3588 * @np: Netdev private structure
3589 * @add: Add or delete flag
3590 * @async: Don't wait for return message
3591 *
3592 * Returns 0 on success, error on failure.
3593 **/
3594int idpf_add_del_mac_filters(struct idpf_vport *vport,
3595 struct idpf_netdev_priv *np,
3596 bool add, bool async)
3597{
3598 struct virtchnl2_mac_addr_list *ma_list __free(kfree) = NULL;
3599 struct virtchnl2_mac_addr *mac_addr __free(kfree) = NULL;
3600 struct idpf_adapter *adapter = np->adapter;
3601 struct idpf_vc_xn_params xn_params = {};
3602 struct idpf_vport_config *vport_config;
3603 u32 num_msgs, total_filters = 0;
3604 struct idpf_mac_filter *f;
3605 ssize_t reply_sz;
3606 int i = 0, k;
3607
3608 xn_params.vc_op = add ? VIRTCHNL2_OP_ADD_MAC_ADDR :
3609 VIRTCHNL2_OP_DEL_MAC_ADDR;
3610 xn_params.timeout_ms = IDPF_VC_XN_DEFAULT_TIMEOUT_MSEC;
3611 xn_params.async = async;
3612 xn_params.async_handler = idpf_mac_filter_async_handler;
3613
3614 vport_config = adapter->vport_config[np->vport_idx];
3615 spin_lock_bh(&vport_config->mac_filter_list_lock);
3616
3617 /* Find the number of newly added filters */
3618 list_for_each_entry(f, &vport_config->user_config.mac_filter_list,
3619 list) {
3620 if (add && f->add)
3621 total_filters++;
3622 else if (!add && f->remove)
3623 total_filters++;
3624 }
3625
3626 if (!total_filters) {
3627 spin_unlock_bh(&vport_config->mac_filter_list_lock);
3628
3629 return 0;
3630 }
3631
3632 /* Fill all the new filters into virtchannel message */
3633 mac_addr = kcalloc(total_filters, sizeof(struct virtchnl2_mac_addr),
3634 GFP_ATOMIC);
3635 if (!mac_addr) {
3636 spin_unlock_bh(&vport_config->mac_filter_list_lock);
3637
3638 return -ENOMEM;
3639 }
3640
3641 list_for_each_entry(f, &vport_config->user_config.mac_filter_list,
3642 list) {
3643 if (add && f->add) {
3644 ether_addr_copy(mac_addr[i].addr, f->macaddr);
3645 i++;
3646 f->add = false;
3647 if (i == total_filters)
3648 break;
3649 }
3650 if (!add && f->remove) {
3651 ether_addr_copy(mac_addr[i].addr, f->macaddr);
3652 i++;
3653 f->remove = false;
3654 if (i == total_filters)
3655 break;
3656 }
3657 }
3658
3659 spin_unlock_bh(&vport_config->mac_filter_list_lock);
3660
3661 /* Chunk up the filters into multiple messages to avoid
3662 * sending a control queue message buffer that is too large
3663 */
3664 num_msgs = DIV_ROUND_UP(total_filters, IDPF_NUM_FILTERS_PER_MSG);
3665
3666 for (i = 0, k = 0; i < num_msgs; i++) {
3667 u32 entries_size, buf_size, num_entries;
3668
3669 num_entries = min_t(u32, total_filters,
3670 IDPF_NUM_FILTERS_PER_MSG);
3671 entries_size = sizeof(struct virtchnl2_mac_addr) * num_entries;
3672 buf_size = struct_size(ma_list, mac_addr_list, num_entries);
3673
3674 if (!ma_list || num_entries != IDPF_NUM_FILTERS_PER_MSG) {
3675 kfree(ma_list);
3676 ma_list = kzalloc(buf_size, GFP_ATOMIC);
3677 if (!ma_list)
3678 return -ENOMEM;
3679 } else {
3680 memset(ma_list, 0, buf_size);
3681 }
3682
3683 ma_list->vport_id = cpu_to_le32(np->vport_id);
3684 ma_list->num_mac_addr = cpu_to_le16(num_entries);
3685 memcpy(ma_list->mac_addr_list, &mac_addr[k], entries_size);
3686
3687 xn_params.send_buf.iov_base = ma_list;
3688 xn_params.send_buf.iov_len = buf_size;
3689 reply_sz = idpf_vc_xn_exec(adapter, &xn_params);
3690 if (reply_sz < 0)
3691 return reply_sz;
3692
3693 k += num_entries;
3694 total_filters -= num_entries;
3695 }
3696
3697 return 0;
3698}
3699
3700/**
3701 * idpf_set_promiscuous - set promiscuous and send message to mailbox
3702 * @adapter: Driver specific private structure
3703 * @config_data: Vport specific config data
3704 * @vport_id: Vport identifier
3705 *
3706 * Request to enable promiscuous mode for the vport. Message is sent
3707 * asynchronously and won't wait for response. Returns 0 on success, negative
3708 * on failure;
3709 */
3710int idpf_set_promiscuous(struct idpf_adapter *adapter,
3711 struct idpf_vport_user_config_data *config_data,
3712 u32 vport_id)
3713{
3714 struct idpf_vc_xn_params xn_params = {};
3715 struct virtchnl2_promisc_info vpi;
3716 ssize_t reply_sz;
3717 u16 flags = 0;
3718
3719 if (test_bit(__IDPF_PROMISC_UC, config_data->user_flags))
3720 flags |= VIRTCHNL2_UNICAST_PROMISC;
3721 if (test_bit(__IDPF_PROMISC_MC, config_data->user_flags))
3722 flags |= VIRTCHNL2_MULTICAST_PROMISC;
3723
3724 vpi.vport_id = cpu_to_le32(vport_id);
3725 vpi.flags = cpu_to_le16(flags);
3726
3727 xn_params.vc_op = VIRTCHNL2_OP_CONFIG_PROMISCUOUS_MODE;
3728 xn_params.timeout_ms = IDPF_VC_XN_DEFAULT_TIMEOUT_MSEC;
3729 xn_params.send_buf.iov_base = &vpi;
3730 xn_params.send_buf.iov_len = sizeof(vpi);
3731 /* setting promiscuous is only ever done asynchronously */
3732 xn_params.async = true;
3733 reply_sz = idpf_vc_xn_exec(adapter, &xn_params);
3734
3735 return reply_sz < 0 ? reply_sz : 0;
3736}
1// SPDX-License-Identifier: GPL-2.0-only
2/* Copyright (C) 2023 Intel Corporation */
3
4#include "idpf.h"
5
6/**
7 * idpf_recv_event_msg - Receive virtchnl event message
8 * @vport: virtual port structure
9 * @ctlq_msg: message to copy from
10 *
11 * Receive virtchnl event message
12 */
13static void idpf_recv_event_msg(struct idpf_vport *vport,
14 struct idpf_ctlq_msg *ctlq_msg)
15{
16 struct idpf_netdev_priv *np = netdev_priv(vport->netdev);
17 struct virtchnl2_event *v2e;
18 bool link_status;
19 u32 event;
20
21 v2e = (struct virtchnl2_event *)ctlq_msg->ctx.indirect.payload->va;
22 event = le32_to_cpu(v2e->event);
23
24 switch (event) {
25 case VIRTCHNL2_EVENT_LINK_CHANGE:
26 vport->link_speed_mbps = le32_to_cpu(v2e->link_speed);
27 link_status = v2e->link_status;
28
29 if (vport->link_up == link_status)
30 break;
31
32 vport->link_up = link_status;
33 if (np->state == __IDPF_VPORT_UP) {
34 if (vport->link_up) {
35 netif_carrier_on(vport->netdev);
36 netif_tx_start_all_queues(vport->netdev);
37 } else {
38 netif_tx_stop_all_queues(vport->netdev);
39 netif_carrier_off(vport->netdev);
40 }
41 }
42 break;
43 default:
44 dev_err(&vport->adapter->pdev->dev,
45 "Unknown event %d from PF\n", event);
46 break;
47 }
48}
49
50/**
51 * idpf_mb_clean - Reclaim the send mailbox queue entries
52 * @adapter: Driver specific private structure
53 *
54 * Reclaim the send mailbox queue entries to be used to send further messages
55 *
56 * Returns 0 on success, negative on failure
57 */
58static int idpf_mb_clean(struct idpf_adapter *adapter)
59{
60 u16 i, num_q_msg = IDPF_DFLT_MBX_Q_LEN;
61 struct idpf_ctlq_msg **q_msg;
62 struct idpf_dma_mem *dma_mem;
63 int err;
64
65 q_msg = kcalloc(num_q_msg, sizeof(struct idpf_ctlq_msg *), GFP_ATOMIC);
66 if (!q_msg)
67 return -ENOMEM;
68
69 err = idpf_ctlq_clean_sq(adapter->hw.asq, &num_q_msg, q_msg);
70 if (err)
71 goto err_kfree;
72
73 for (i = 0; i < num_q_msg; i++) {
74 if (!q_msg[i])
75 continue;
76 dma_mem = q_msg[i]->ctx.indirect.payload;
77 if (dma_mem)
78 dma_free_coherent(&adapter->pdev->dev, dma_mem->size,
79 dma_mem->va, dma_mem->pa);
80 kfree(q_msg[i]);
81 kfree(dma_mem);
82 }
83
84err_kfree:
85 kfree(q_msg);
86
87 return err;
88}
89
90/**
91 * idpf_send_mb_msg - Send message over mailbox
92 * @adapter: Driver specific private structure
93 * @op: virtchnl opcode
94 * @msg_size: size of the payload
95 * @msg: pointer to buffer holding the payload
96 *
97 * Will prepare the control queue message and initiates the send api
98 *
99 * Returns 0 on success, negative on failure
100 */
101int idpf_send_mb_msg(struct idpf_adapter *adapter, u32 op,
102 u16 msg_size, u8 *msg)
103{
104 struct idpf_ctlq_msg *ctlq_msg;
105 struct idpf_dma_mem *dma_mem;
106 int err;
107
108 /* If we are here and a reset is detected nothing much can be
109 * done. This thread should silently abort and expected to
110 * be corrected with a new run either by user or driver
111 * flows after reset
112 */
113 if (idpf_is_reset_detected(adapter))
114 return 0;
115
116 err = idpf_mb_clean(adapter);
117 if (err)
118 return err;
119
120 ctlq_msg = kzalloc(sizeof(*ctlq_msg), GFP_ATOMIC);
121 if (!ctlq_msg)
122 return -ENOMEM;
123
124 dma_mem = kzalloc(sizeof(*dma_mem), GFP_ATOMIC);
125 if (!dma_mem) {
126 err = -ENOMEM;
127 goto dma_mem_error;
128 }
129
130 ctlq_msg->opcode = idpf_mbq_opc_send_msg_to_cp;
131 ctlq_msg->func_id = 0;
132 ctlq_msg->data_len = msg_size;
133 ctlq_msg->cookie.mbx.chnl_opcode = op;
134 ctlq_msg->cookie.mbx.chnl_retval = 0;
135 dma_mem->size = IDPF_CTLQ_MAX_BUF_LEN;
136 dma_mem->va = dma_alloc_coherent(&adapter->pdev->dev, dma_mem->size,
137 &dma_mem->pa, GFP_ATOMIC);
138 if (!dma_mem->va) {
139 err = -ENOMEM;
140 goto dma_alloc_error;
141 }
142 memcpy(dma_mem->va, msg, msg_size);
143 ctlq_msg->ctx.indirect.payload = dma_mem;
144
145 err = idpf_ctlq_send(&adapter->hw, adapter->hw.asq, 1, ctlq_msg);
146 if (err)
147 goto send_error;
148
149 return 0;
150
151send_error:
152 dma_free_coherent(&adapter->pdev->dev, dma_mem->size, dma_mem->va,
153 dma_mem->pa);
154dma_alloc_error:
155 kfree(dma_mem);
156dma_mem_error:
157 kfree(ctlq_msg);
158
159 return err;
160}
161
162/**
163 * idpf_find_vport - Find vport pointer from control queue message
164 * @adapter: driver specific private structure
165 * @vport: address of vport pointer to copy the vport from adapters vport list
166 * @ctlq_msg: control queue message
167 *
168 * Return 0 on success, error value on failure. Also this function does check
169 * for the opcodes which expect to receive payload and return error value if
170 * it is not the case.
171 */
172static int idpf_find_vport(struct idpf_adapter *adapter,
173 struct idpf_vport **vport,
174 struct idpf_ctlq_msg *ctlq_msg)
175{
176 bool no_op = false, vid_found = false;
177 int i, err = 0;
178 char *vc_msg;
179 u32 v_id;
180
181 vc_msg = kcalloc(IDPF_CTLQ_MAX_BUF_LEN, sizeof(char), GFP_KERNEL);
182 if (!vc_msg)
183 return -ENOMEM;
184
185 if (ctlq_msg->data_len) {
186 size_t payload_size = ctlq_msg->ctx.indirect.payload->size;
187
188 if (!payload_size) {
189 dev_err(&adapter->pdev->dev, "Failed to receive payload buffer\n");
190 kfree(vc_msg);
191
192 return -EINVAL;
193 }
194
195 memcpy(vc_msg, ctlq_msg->ctx.indirect.payload->va,
196 min_t(size_t, payload_size, IDPF_CTLQ_MAX_BUF_LEN));
197 }
198
199 switch (ctlq_msg->cookie.mbx.chnl_opcode) {
200 case VIRTCHNL2_OP_VERSION:
201 case VIRTCHNL2_OP_GET_CAPS:
202 case VIRTCHNL2_OP_CREATE_VPORT:
203 case VIRTCHNL2_OP_SET_SRIOV_VFS:
204 case VIRTCHNL2_OP_ALLOC_VECTORS:
205 case VIRTCHNL2_OP_DEALLOC_VECTORS:
206 case VIRTCHNL2_OP_GET_PTYPE_INFO:
207 goto free_vc_msg;
208 case VIRTCHNL2_OP_ENABLE_VPORT:
209 case VIRTCHNL2_OP_DISABLE_VPORT:
210 case VIRTCHNL2_OP_DESTROY_VPORT:
211 v_id = le32_to_cpu(((struct virtchnl2_vport *)vc_msg)->vport_id);
212 break;
213 case VIRTCHNL2_OP_CONFIG_TX_QUEUES:
214 v_id = le32_to_cpu(((struct virtchnl2_config_tx_queues *)vc_msg)->vport_id);
215 break;
216 case VIRTCHNL2_OP_CONFIG_RX_QUEUES:
217 v_id = le32_to_cpu(((struct virtchnl2_config_rx_queues *)vc_msg)->vport_id);
218 break;
219 case VIRTCHNL2_OP_ENABLE_QUEUES:
220 case VIRTCHNL2_OP_DISABLE_QUEUES:
221 case VIRTCHNL2_OP_DEL_QUEUES:
222 v_id = le32_to_cpu(((struct virtchnl2_del_ena_dis_queues *)vc_msg)->vport_id);
223 break;
224 case VIRTCHNL2_OP_ADD_QUEUES:
225 v_id = le32_to_cpu(((struct virtchnl2_add_queues *)vc_msg)->vport_id);
226 break;
227 case VIRTCHNL2_OP_MAP_QUEUE_VECTOR:
228 case VIRTCHNL2_OP_UNMAP_QUEUE_VECTOR:
229 v_id = le32_to_cpu(((struct virtchnl2_queue_vector_maps *)vc_msg)->vport_id);
230 break;
231 case VIRTCHNL2_OP_GET_STATS:
232 v_id = le32_to_cpu(((struct virtchnl2_vport_stats *)vc_msg)->vport_id);
233 break;
234 case VIRTCHNL2_OP_GET_RSS_LUT:
235 case VIRTCHNL2_OP_SET_RSS_LUT:
236 v_id = le32_to_cpu(((struct virtchnl2_rss_lut *)vc_msg)->vport_id);
237 break;
238 case VIRTCHNL2_OP_GET_RSS_KEY:
239 case VIRTCHNL2_OP_SET_RSS_KEY:
240 v_id = le32_to_cpu(((struct virtchnl2_rss_key *)vc_msg)->vport_id);
241 break;
242 case VIRTCHNL2_OP_EVENT:
243 v_id = le32_to_cpu(((struct virtchnl2_event *)vc_msg)->vport_id);
244 break;
245 case VIRTCHNL2_OP_LOOPBACK:
246 v_id = le32_to_cpu(((struct virtchnl2_loopback *)vc_msg)->vport_id);
247 break;
248 case VIRTCHNL2_OP_CONFIG_PROMISCUOUS_MODE:
249 v_id = le32_to_cpu(((struct virtchnl2_promisc_info *)vc_msg)->vport_id);
250 break;
251 case VIRTCHNL2_OP_ADD_MAC_ADDR:
252 case VIRTCHNL2_OP_DEL_MAC_ADDR:
253 v_id = le32_to_cpu(((struct virtchnl2_mac_addr_list *)vc_msg)->vport_id);
254 break;
255 default:
256 no_op = true;
257 break;
258 }
259
260 if (no_op)
261 goto free_vc_msg;
262
263 for (i = 0; i < idpf_get_max_vports(adapter); i++) {
264 if (adapter->vport_ids[i] == v_id) {
265 vid_found = true;
266 break;
267 }
268 }
269
270 if (vid_found)
271 *vport = adapter->vports[i];
272 else
273 err = -EINVAL;
274
275free_vc_msg:
276 kfree(vc_msg);
277
278 return err;
279}
280
281/**
282 * idpf_copy_data_to_vc_buf - Copy the virtchnl response data into the buffer.
283 * @adapter: driver specific private structure
284 * @vport: virtual port structure
285 * @ctlq_msg: msg to copy from
286 * @err_enum: err bit to set on error
287 *
288 * Copies the payload from ctlq_msg into virtchnl buffer. Returns 0 on success,
289 * negative on failure.
290 */
291static int idpf_copy_data_to_vc_buf(struct idpf_adapter *adapter,
292 struct idpf_vport *vport,
293 struct idpf_ctlq_msg *ctlq_msg,
294 enum idpf_vport_vc_state err_enum)
295{
296 if (ctlq_msg->cookie.mbx.chnl_retval) {
297 if (vport)
298 set_bit(err_enum, vport->vc_state);
299 else
300 set_bit(err_enum, adapter->vc_state);
301
302 return -EINVAL;
303 }
304
305 if (vport)
306 memcpy(vport->vc_msg, ctlq_msg->ctx.indirect.payload->va,
307 min_t(int, ctlq_msg->ctx.indirect.payload->size,
308 IDPF_CTLQ_MAX_BUF_LEN));
309 else
310 memcpy(adapter->vc_msg, ctlq_msg->ctx.indirect.payload->va,
311 min_t(int, ctlq_msg->ctx.indirect.payload->size,
312 IDPF_CTLQ_MAX_BUF_LEN));
313
314 return 0;
315}
316
317/**
318 * idpf_recv_vchnl_op - helper function with common logic when handling the
319 * reception of VIRTCHNL OPs.
320 * @adapter: driver specific private structure
321 * @vport: virtual port structure
322 * @ctlq_msg: msg to copy from
323 * @state: state bit used on timeout check
324 * @err_state: err bit to set on error
325 */
326static void idpf_recv_vchnl_op(struct idpf_adapter *adapter,
327 struct idpf_vport *vport,
328 struct idpf_ctlq_msg *ctlq_msg,
329 enum idpf_vport_vc_state state,
330 enum idpf_vport_vc_state err_state)
331{
332 wait_queue_head_t *vchnl_wq;
333 int err;
334
335 if (vport)
336 vchnl_wq = &vport->vchnl_wq;
337 else
338 vchnl_wq = &adapter->vchnl_wq;
339
340 err = idpf_copy_data_to_vc_buf(adapter, vport, ctlq_msg, err_state);
341 if (wq_has_sleeper(vchnl_wq)) {
342 if (vport)
343 set_bit(state, vport->vc_state);
344 else
345 set_bit(state, adapter->vc_state);
346
347 wake_up(vchnl_wq);
348 } else {
349 if (!err) {
350 dev_warn(&adapter->pdev->dev, "opcode %d received without waiting thread\n",
351 ctlq_msg->cookie.mbx.chnl_opcode);
352 } else {
353 /* Clear the errors since there is no sleeper to pass
354 * them on
355 */
356 if (vport)
357 clear_bit(err_state, vport->vc_state);
358 else
359 clear_bit(err_state, adapter->vc_state);
360 }
361 }
362}
363
364/**
365 * idpf_recv_mb_msg - Receive message over mailbox
366 * @adapter: Driver specific private structure
367 * @op: virtchannel operation code
368 * @msg: Received message holding buffer
369 * @msg_size: message size
370 *
371 * Will receive control queue message and posts the receive buffer. Returns 0
372 * on success and negative on failure.
373 */
374int idpf_recv_mb_msg(struct idpf_adapter *adapter, u32 op,
375 void *msg, int msg_size)
376{
377 struct idpf_vport *vport = NULL;
378 struct idpf_ctlq_msg ctlq_msg;
379 struct idpf_dma_mem *dma_mem;
380 bool work_done = false;
381 int num_retry = 2000;
382 u16 num_q_msg;
383 int err;
384
385 while (1) {
386 struct idpf_vport_config *vport_config;
387 int payload_size = 0;
388
389 /* Try to get one message */
390 num_q_msg = 1;
391 dma_mem = NULL;
392 err = idpf_ctlq_recv(adapter->hw.arq, &num_q_msg, &ctlq_msg);
393 /* If no message then decide if we have to retry based on
394 * opcode
395 */
396 if (err || !num_q_msg) {
397 /* Increasing num_retry to consider the delayed
398 * responses because of large number of VF's mailbox
399 * messages. If the mailbox message is received from
400 * the other side, we come out of the sleep cycle
401 * immediately else we wait for more time.
402 */
403 if (!op || !num_retry--)
404 break;
405 if (test_bit(IDPF_REMOVE_IN_PROG, adapter->flags)) {
406 err = -EIO;
407 break;
408 }
409 msleep(20);
410 continue;
411 }
412
413 /* If we are here a message is received. Check if we are looking
414 * for a specific message based on opcode. If it is different
415 * ignore and post buffers
416 */
417 if (op && ctlq_msg.cookie.mbx.chnl_opcode != op)
418 goto post_buffs;
419
420 err = idpf_find_vport(adapter, &vport, &ctlq_msg);
421 if (err)
422 goto post_buffs;
423
424 if (ctlq_msg.data_len)
425 payload_size = ctlq_msg.ctx.indirect.payload->size;
426
427 /* All conditions are met. Either a message requested is
428 * received or we received a message to be processed
429 */
430 switch (ctlq_msg.cookie.mbx.chnl_opcode) {
431 case VIRTCHNL2_OP_VERSION:
432 case VIRTCHNL2_OP_GET_CAPS:
433 if (ctlq_msg.cookie.mbx.chnl_retval) {
434 dev_err(&adapter->pdev->dev, "Failure initializing, vc op: %u retval: %u\n",
435 ctlq_msg.cookie.mbx.chnl_opcode,
436 ctlq_msg.cookie.mbx.chnl_retval);
437 err = -EBADMSG;
438 } else if (msg) {
439 memcpy(msg, ctlq_msg.ctx.indirect.payload->va,
440 min_t(int, payload_size, msg_size));
441 }
442 work_done = true;
443 break;
444 case VIRTCHNL2_OP_CREATE_VPORT:
445 idpf_recv_vchnl_op(adapter, NULL, &ctlq_msg,
446 IDPF_VC_CREATE_VPORT,
447 IDPF_VC_CREATE_VPORT_ERR);
448 break;
449 case VIRTCHNL2_OP_ENABLE_VPORT:
450 idpf_recv_vchnl_op(adapter, vport, &ctlq_msg,
451 IDPF_VC_ENA_VPORT,
452 IDPF_VC_ENA_VPORT_ERR);
453 break;
454 case VIRTCHNL2_OP_DISABLE_VPORT:
455 idpf_recv_vchnl_op(adapter, vport, &ctlq_msg,
456 IDPF_VC_DIS_VPORT,
457 IDPF_VC_DIS_VPORT_ERR);
458 break;
459 case VIRTCHNL2_OP_DESTROY_VPORT:
460 idpf_recv_vchnl_op(adapter, vport, &ctlq_msg,
461 IDPF_VC_DESTROY_VPORT,
462 IDPF_VC_DESTROY_VPORT_ERR);
463 break;
464 case VIRTCHNL2_OP_CONFIG_TX_QUEUES:
465 idpf_recv_vchnl_op(adapter, vport, &ctlq_msg,
466 IDPF_VC_CONFIG_TXQ,
467 IDPF_VC_CONFIG_TXQ_ERR);
468 break;
469 case VIRTCHNL2_OP_CONFIG_RX_QUEUES:
470 idpf_recv_vchnl_op(adapter, vport, &ctlq_msg,
471 IDPF_VC_CONFIG_RXQ,
472 IDPF_VC_CONFIG_RXQ_ERR);
473 break;
474 case VIRTCHNL2_OP_ENABLE_QUEUES:
475 idpf_recv_vchnl_op(adapter, vport, &ctlq_msg,
476 IDPF_VC_ENA_QUEUES,
477 IDPF_VC_ENA_QUEUES_ERR);
478 break;
479 case VIRTCHNL2_OP_DISABLE_QUEUES:
480 idpf_recv_vchnl_op(adapter, vport, &ctlq_msg,
481 IDPF_VC_DIS_QUEUES,
482 IDPF_VC_DIS_QUEUES_ERR);
483 break;
484 case VIRTCHNL2_OP_ADD_QUEUES:
485 idpf_recv_vchnl_op(adapter, vport, &ctlq_msg,
486 IDPF_VC_ADD_QUEUES,
487 IDPF_VC_ADD_QUEUES_ERR);
488 break;
489 case VIRTCHNL2_OP_DEL_QUEUES:
490 idpf_recv_vchnl_op(adapter, vport, &ctlq_msg,
491 IDPF_VC_DEL_QUEUES,
492 IDPF_VC_DEL_QUEUES_ERR);
493 break;
494 case VIRTCHNL2_OP_MAP_QUEUE_VECTOR:
495 idpf_recv_vchnl_op(adapter, vport, &ctlq_msg,
496 IDPF_VC_MAP_IRQ,
497 IDPF_VC_MAP_IRQ_ERR);
498 break;
499 case VIRTCHNL2_OP_UNMAP_QUEUE_VECTOR:
500 idpf_recv_vchnl_op(adapter, vport, &ctlq_msg,
501 IDPF_VC_UNMAP_IRQ,
502 IDPF_VC_UNMAP_IRQ_ERR);
503 break;
504 case VIRTCHNL2_OP_GET_STATS:
505 idpf_recv_vchnl_op(adapter, vport, &ctlq_msg,
506 IDPF_VC_GET_STATS,
507 IDPF_VC_GET_STATS_ERR);
508 break;
509 case VIRTCHNL2_OP_GET_RSS_LUT:
510 idpf_recv_vchnl_op(adapter, vport, &ctlq_msg,
511 IDPF_VC_GET_RSS_LUT,
512 IDPF_VC_GET_RSS_LUT_ERR);
513 break;
514 case VIRTCHNL2_OP_SET_RSS_LUT:
515 idpf_recv_vchnl_op(adapter, vport, &ctlq_msg,
516 IDPF_VC_SET_RSS_LUT,
517 IDPF_VC_SET_RSS_LUT_ERR);
518 break;
519 case VIRTCHNL2_OP_GET_RSS_KEY:
520 idpf_recv_vchnl_op(adapter, vport, &ctlq_msg,
521 IDPF_VC_GET_RSS_KEY,
522 IDPF_VC_GET_RSS_KEY_ERR);
523 break;
524 case VIRTCHNL2_OP_SET_RSS_KEY:
525 idpf_recv_vchnl_op(adapter, vport, &ctlq_msg,
526 IDPF_VC_SET_RSS_KEY,
527 IDPF_VC_SET_RSS_KEY_ERR);
528 break;
529 case VIRTCHNL2_OP_SET_SRIOV_VFS:
530 idpf_recv_vchnl_op(adapter, NULL, &ctlq_msg,
531 IDPF_VC_SET_SRIOV_VFS,
532 IDPF_VC_SET_SRIOV_VFS_ERR);
533 break;
534 case VIRTCHNL2_OP_ALLOC_VECTORS:
535 idpf_recv_vchnl_op(adapter, NULL, &ctlq_msg,
536 IDPF_VC_ALLOC_VECTORS,
537 IDPF_VC_ALLOC_VECTORS_ERR);
538 break;
539 case VIRTCHNL2_OP_DEALLOC_VECTORS:
540 idpf_recv_vchnl_op(adapter, NULL, &ctlq_msg,
541 IDPF_VC_DEALLOC_VECTORS,
542 IDPF_VC_DEALLOC_VECTORS_ERR);
543 break;
544 case VIRTCHNL2_OP_GET_PTYPE_INFO:
545 idpf_recv_vchnl_op(adapter, NULL, &ctlq_msg,
546 IDPF_VC_GET_PTYPE_INFO,
547 IDPF_VC_GET_PTYPE_INFO_ERR);
548 break;
549 case VIRTCHNL2_OP_LOOPBACK:
550 idpf_recv_vchnl_op(adapter, vport, &ctlq_msg,
551 IDPF_VC_LOOPBACK_STATE,
552 IDPF_VC_LOOPBACK_STATE_ERR);
553 break;
554 case VIRTCHNL2_OP_CONFIG_PROMISCUOUS_MODE:
555 /* This message can only be sent asynchronously. As
556 * such we'll have lost the context in which it was
557 * called and thus can only really report if it looks
558 * like an error occurred. Don't bother setting ERR bit
559 * or waking chnl_wq since no work queue will be waiting
560 * to read the message.
561 */
562 if (ctlq_msg.cookie.mbx.chnl_retval) {
563 dev_err(&adapter->pdev->dev, "Failed to set promiscuous mode: %d\n",
564 ctlq_msg.cookie.mbx.chnl_retval);
565 }
566 break;
567 case VIRTCHNL2_OP_ADD_MAC_ADDR:
568 vport_config = adapter->vport_config[vport->idx];
569 if (test_and_clear_bit(IDPF_VPORT_ADD_MAC_REQ,
570 vport_config->flags)) {
571 /* Message was sent asynchronously. We don't
572 * normally print errors here, instead
573 * prefer to handle errors in the function
574 * calling wait_for_event. However, if
575 * asynchronous, the context in which the
576 * message was sent is lost. We can't really do
577 * anything about at it this point, but we
578 * should at a minimum indicate that it looks
579 * like something went wrong. Also don't bother
580 * setting ERR bit or waking vchnl_wq since no
581 * one will be waiting to read the async
582 * message.
583 */
584 if (ctlq_msg.cookie.mbx.chnl_retval)
585 dev_err(&adapter->pdev->dev, "Failed to add MAC address: %d\n",
586 ctlq_msg.cookie.mbx.chnl_retval);
587 break;
588 }
589 idpf_recv_vchnl_op(adapter, vport, &ctlq_msg,
590 IDPF_VC_ADD_MAC_ADDR,
591 IDPF_VC_ADD_MAC_ADDR_ERR);
592 break;
593 case VIRTCHNL2_OP_DEL_MAC_ADDR:
594 vport_config = adapter->vport_config[vport->idx];
595 if (test_and_clear_bit(IDPF_VPORT_DEL_MAC_REQ,
596 vport_config->flags)) {
597 /* Message was sent asynchronously like the
598 * VIRTCHNL2_OP_ADD_MAC_ADDR
599 */
600 if (ctlq_msg.cookie.mbx.chnl_retval)
601 dev_err(&adapter->pdev->dev, "Failed to delete MAC address: %d\n",
602 ctlq_msg.cookie.mbx.chnl_retval);
603 break;
604 }
605 idpf_recv_vchnl_op(adapter, vport, &ctlq_msg,
606 IDPF_VC_DEL_MAC_ADDR,
607 IDPF_VC_DEL_MAC_ADDR_ERR);
608 break;
609 case VIRTCHNL2_OP_EVENT:
610 idpf_recv_event_msg(vport, &ctlq_msg);
611 break;
612 default:
613 dev_warn(&adapter->pdev->dev,
614 "Unhandled virtchnl response %d\n",
615 ctlq_msg.cookie.mbx.chnl_opcode);
616 break;
617 }
618
619post_buffs:
620 if (ctlq_msg.data_len)
621 dma_mem = ctlq_msg.ctx.indirect.payload;
622 else
623 num_q_msg = 0;
624
625 err = idpf_ctlq_post_rx_buffs(&adapter->hw, adapter->hw.arq,
626 &num_q_msg, &dma_mem);
627 /* If post failed clear the only buffer we supplied */
628 if (err && dma_mem)
629 dma_free_coherent(&adapter->pdev->dev, dma_mem->size,
630 dma_mem->va, dma_mem->pa);
631
632 /* Applies only if we are looking for a specific opcode */
633 if (work_done)
634 break;
635 }
636
637 return err;
638}
639
640/**
641 * __idpf_wait_for_event - wrapper function for wait on virtchannel response
642 * @adapter: Driver private data structure
643 * @vport: virtual port structure
644 * @state: check on state upon timeout
645 * @err_check: check if this specific error bit is set
646 * @timeout: Max time to wait
647 *
648 * Checks if state is set upon expiry of timeout. Returns 0 on success,
649 * negative on failure.
650 */
651static int __idpf_wait_for_event(struct idpf_adapter *adapter,
652 struct idpf_vport *vport,
653 enum idpf_vport_vc_state state,
654 enum idpf_vport_vc_state err_check,
655 int timeout)
656{
657 int time_to_wait, num_waits;
658 wait_queue_head_t *vchnl_wq;
659 unsigned long *vc_state;
660
661 time_to_wait = ((timeout <= IDPF_MAX_WAIT) ? timeout : IDPF_MAX_WAIT);
662 num_waits = ((timeout <= IDPF_MAX_WAIT) ? 1 : timeout / IDPF_MAX_WAIT);
663
664 if (vport) {
665 vchnl_wq = &vport->vchnl_wq;
666 vc_state = vport->vc_state;
667 } else {
668 vchnl_wq = &adapter->vchnl_wq;
669 vc_state = adapter->vc_state;
670 }
671
672 while (num_waits) {
673 int event;
674
675 /* If we are here and a reset is detected do not wait but
676 * return. Reset timing is out of drivers control. So
677 * while we are cleaning resources as part of reset if the
678 * underlying HW mailbox is gone, wait on mailbox messages
679 * is not meaningful
680 */
681 if (idpf_is_reset_detected(adapter))
682 return 0;
683
684 event = wait_event_timeout(*vchnl_wq,
685 test_and_clear_bit(state, vc_state),
686 msecs_to_jiffies(time_to_wait));
687 if (event) {
688 if (test_and_clear_bit(err_check, vc_state)) {
689 dev_err(&adapter->pdev->dev, "VC response error %s\n",
690 idpf_vport_vc_state_str[err_check]);
691
692 return -EINVAL;
693 }
694
695 return 0;
696 }
697 num_waits--;
698 }
699
700 /* Timeout occurred */
701 dev_err(&adapter->pdev->dev, "VC timeout, state = %s\n",
702 idpf_vport_vc_state_str[state]);
703
704 return -ETIMEDOUT;
705}
706
707/**
708 * idpf_min_wait_for_event - wait for virtchannel response
709 * @adapter: Driver private data structure
710 * @vport: virtual port structure
711 * @state: check on state upon timeout
712 * @err_check: check if this specific error bit is set
713 *
714 * Returns 0 on success, negative on failure.
715 */
716static int idpf_min_wait_for_event(struct idpf_adapter *adapter,
717 struct idpf_vport *vport,
718 enum idpf_vport_vc_state state,
719 enum idpf_vport_vc_state err_check)
720{
721 return __idpf_wait_for_event(adapter, vport, state, err_check,
722 IDPF_WAIT_FOR_EVENT_TIMEO_MIN);
723}
724
725/**
726 * idpf_wait_for_event - wait for virtchannel response
727 * @adapter: Driver private data structure
728 * @vport: virtual port structure
729 * @state: check on state upon timeout after 500ms
730 * @err_check: check if this specific error bit is set
731 *
732 * Returns 0 on success, negative on failure.
733 */
734static int idpf_wait_for_event(struct idpf_adapter *adapter,
735 struct idpf_vport *vport,
736 enum idpf_vport_vc_state state,
737 enum idpf_vport_vc_state err_check)
738{
739 /* Increasing the timeout in __IDPF_INIT_SW flow to consider large
740 * number of VF's mailbox message responses. When a message is received
741 * on mailbox, this thread is woken up by the idpf_recv_mb_msg before
742 * the timeout expires. Only in the error case i.e. if no message is
743 * received on mailbox, we wait for the complete timeout which is
744 * less likely to happen.
745 */
746 return __idpf_wait_for_event(adapter, vport, state, err_check,
747 IDPF_WAIT_FOR_EVENT_TIMEO);
748}
749
750/**
751 * idpf_wait_for_marker_event - wait for software marker response
752 * @vport: virtual port data structure
753 *
754 * Returns 0 success, negative on failure.
755 **/
756static int idpf_wait_for_marker_event(struct idpf_vport *vport)
757{
758 int event;
759 int i;
760
761 for (i = 0; i < vport->num_txq; i++)
762 set_bit(__IDPF_Q_SW_MARKER, vport->txqs[i]->flags);
763
764 event = wait_event_timeout(vport->sw_marker_wq,
765 test_and_clear_bit(IDPF_VPORT_SW_MARKER,
766 vport->flags),
767 msecs_to_jiffies(500));
768
769 for (i = 0; i < vport->num_txq; i++)
770 clear_bit(__IDPF_Q_POLL_MODE, vport->txqs[i]->flags);
771
772 if (event)
773 return 0;
774
775 dev_warn(&vport->adapter->pdev->dev, "Failed to receive marker packets\n");
776
777 return -ETIMEDOUT;
778}
779
780/**
781 * idpf_send_ver_msg - send virtchnl version message
782 * @adapter: Driver specific private structure
783 *
784 * Send virtchnl version message. Returns 0 on success, negative on failure.
785 */
786static int idpf_send_ver_msg(struct idpf_adapter *adapter)
787{
788 struct virtchnl2_version_info vvi;
789
790 if (adapter->virt_ver_maj) {
791 vvi.major = cpu_to_le32(adapter->virt_ver_maj);
792 vvi.minor = cpu_to_le32(adapter->virt_ver_min);
793 } else {
794 vvi.major = cpu_to_le32(IDPF_VIRTCHNL_VERSION_MAJOR);
795 vvi.minor = cpu_to_le32(IDPF_VIRTCHNL_VERSION_MINOR);
796 }
797
798 return idpf_send_mb_msg(adapter, VIRTCHNL2_OP_VERSION, sizeof(vvi),
799 (u8 *)&vvi);
800}
801
802/**
803 * idpf_recv_ver_msg - Receive virtchnl version message
804 * @adapter: Driver specific private structure
805 *
806 * Receive virtchnl version message. Returns 0 on success, -EAGAIN if we need
807 * to send version message again, otherwise negative on failure.
808 */
809static int idpf_recv_ver_msg(struct idpf_adapter *adapter)
810{
811 struct virtchnl2_version_info vvi;
812 u32 major, minor;
813 int err;
814
815 err = idpf_recv_mb_msg(adapter, VIRTCHNL2_OP_VERSION, &vvi,
816 sizeof(vvi));
817 if (err)
818 return err;
819
820 major = le32_to_cpu(vvi.major);
821 minor = le32_to_cpu(vvi.minor);
822
823 if (major > IDPF_VIRTCHNL_VERSION_MAJOR) {
824 dev_warn(&adapter->pdev->dev,
825 "Virtchnl major version (%d) greater than supported\n",
826 major);
827
828 return -EINVAL;
829 }
830
831 if (major == IDPF_VIRTCHNL_VERSION_MAJOR &&
832 minor > IDPF_VIRTCHNL_VERSION_MINOR)
833 dev_warn(&adapter->pdev->dev,
834 "Virtchnl minor version (%d) didn't match\n", minor);
835
836 /* If we have a mismatch, resend version to update receiver on what
837 * version we will use.
838 */
839 if (!adapter->virt_ver_maj &&
840 major != IDPF_VIRTCHNL_VERSION_MAJOR &&
841 minor != IDPF_VIRTCHNL_VERSION_MINOR)
842 err = -EAGAIN;
843
844 adapter->virt_ver_maj = major;
845 adapter->virt_ver_min = minor;
846
847 return err;
848}
849
850/**
851 * idpf_send_get_caps_msg - Send virtchnl get capabilities message
852 * @adapter: Driver specific private structure
853 *
854 * Send virtchl get capabilities message. Returns 0 on success, negative on
855 * failure.
856 */
857static int idpf_send_get_caps_msg(struct idpf_adapter *adapter)
858{
859 struct virtchnl2_get_capabilities caps = { };
860
861 caps.csum_caps =
862 cpu_to_le32(VIRTCHNL2_CAP_TX_CSUM_L3_IPV4 |
863 VIRTCHNL2_CAP_TX_CSUM_L4_IPV4_TCP |
864 VIRTCHNL2_CAP_TX_CSUM_L4_IPV4_UDP |
865 VIRTCHNL2_CAP_TX_CSUM_L4_IPV4_SCTP |
866 VIRTCHNL2_CAP_TX_CSUM_L4_IPV6_TCP |
867 VIRTCHNL2_CAP_TX_CSUM_L4_IPV6_UDP |
868 VIRTCHNL2_CAP_TX_CSUM_L4_IPV6_SCTP |
869 VIRTCHNL2_CAP_RX_CSUM_L3_IPV4 |
870 VIRTCHNL2_CAP_RX_CSUM_L4_IPV4_TCP |
871 VIRTCHNL2_CAP_RX_CSUM_L4_IPV4_UDP |
872 VIRTCHNL2_CAP_RX_CSUM_L4_IPV4_SCTP |
873 VIRTCHNL2_CAP_RX_CSUM_L4_IPV6_TCP |
874 VIRTCHNL2_CAP_RX_CSUM_L4_IPV6_UDP |
875 VIRTCHNL2_CAP_RX_CSUM_L4_IPV6_SCTP |
876 VIRTCHNL2_CAP_TX_CSUM_L3_SINGLE_TUNNEL |
877 VIRTCHNL2_CAP_RX_CSUM_L3_SINGLE_TUNNEL |
878 VIRTCHNL2_CAP_TX_CSUM_L4_SINGLE_TUNNEL |
879 VIRTCHNL2_CAP_RX_CSUM_L4_SINGLE_TUNNEL |
880 VIRTCHNL2_CAP_RX_CSUM_GENERIC);
881
882 caps.seg_caps =
883 cpu_to_le32(VIRTCHNL2_CAP_SEG_IPV4_TCP |
884 VIRTCHNL2_CAP_SEG_IPV4_UDP |
885 VIRTCHNL2_CAP_SEG_IPV4_SCTP |
886 VIRTCHNL2_CAP_SEG_IPV6_TCP |
887 VIRTCHNL2_CAP_SEG_IPV6_UDP |
888 VIRTCHNL2_CAP_SEG_IPV6_SCTP |
889 VIRTCHNL2_CAP_SEG_TX_SINGLE_TUNNEL);
890
891 caps.rss_caps =
892 cpu_to_le64(VIRTCHNL2_CAP_RSS_IPV4_TCP |
893 VIRTCHNL2_CAP_RSS_IPV4_UDP |
894 VIRTCHNL2_CAP_RSS_IPV4_SCTP |
895 VIRTCHNL2_CAP_RSS_IPV4_OTHER |
896 VIRTCHNL2_CAP_RSS_IPV6_TCP |
897 VIRTCHNL2_CAP_RSS_IPV6_UDP |
898 VIRTCHNL2_CAP_RSS_IPV6_SCTP |
899 VIRTCHNL2_CAP_RSS_IPV6_OTHER);
900
901 caps.hsplit_caps =
902 cpu_to_le32(VIRTCHNL2_CAP_RX_HSPLIT_AT_L4V4 |
903 VIRTCHNL2_CAP_RX_HSPLIT_AT_L4V6);
904
905 caps.rsc_caps =
906 cpu_to_le32(VIRTCHNL2_CAP_RSC_IPV4_TCP |
907 VIRTCHNL2_CAP_RSC_IPV6_TCP);
908
909 caps.other_caps =
910 cpu_to_le64(VIRTCHNL2_CAP_SRIOV |
911 VIRTCHNL2_CAP_MACFILTER |
912 VIRTCHNL2_CAP_SPLITQ_QSCHED |
913 VIRTCHNL2_CAP_PROMISC |
914 VIRTCHNL2_CAP_LOOPBACK);
915
916 return idpf_send_mb_msg(adapter, VIRTCHNL2_OP_GET_CAPS, sizeof(caps),
917 (u8 *)&caps);
918}
919
920/**
921 * idpf_recv_get_caps_msg - Receive virtchnl get capabilities message
922 * @adapter: Driver specific private structure
923 *
924 * Receive virtchnl get capabilities message. Returns 0 on success, negative on
925 * failure.
926 */
927static int idpf_recv_get_caps_msg(struct idpf_adapter *adapter)
928{
929 return idpf_recv_mb_msg(adapter, VIRTCHNL2_OP_GET_CAPS, &adapter->caps,
930 sizeof(struct virtchnl2_get_capabilities));
931}
932
933/**
934 * idpf_vport_alloc_max_qs - Allocate max queues for a vport
935 * @adapter: Driver specific private structure
936 * @max_q: vport max queue structure
937 */
938int idpf_vport_alloc_max_qs(struct idpf_adapter *adapter,
939 struct idpf_vport_max_q *max_q)
940{
941 struct idpf_avail_queue_info *avail_queues = &adapter->avail_queues;
942 struct virtchnl2_get_capabilities *caps = &adapter->caps;
943 u16 default_vports = idpf_get_default_vports(adapter);
944 int max_rx_q, max_tx_q;
945
946 mutex_lock(&adapter->queue_lock);
947
948 max_rx_q = le16_to_cpu(caps->max_rx_q) / default_vports;
949 max_tx_q = le16_to_cpu(caps->max_tx_q) / default_vports;
950 if (adapter->num_alloc_vports < default_vports) {
951 max_q->max_rxq = min_t(u16, max_rx_q, IDPF_MAX_Q);
952 max_q->max_txq = min_t(u16, max_tx_q, IDPF_MAX_Q);
953 } else {
954 max_q->max_rxq = IDPF_MIN_Q;
955 max_q->max_txq = IDPF_MIN_Q;
956 }
957 max_q->max_bufq = max_q->max_rxq * IDPF_MAX_BUFQS_PER_RXQ_GRP;
958 max_q->max_complq = max_q->max_txq;
959
960 if (avail_queues->avail_rxq < max_q->max_rxq ||
961 avail_queues->avail_txq < max_q->max_txq ||
962 avail_queues->avail_bufq < max_q->max_bufq ||
963 avail_queues->avail_complq < max_q->max_complq) {
964 mutex_unlock(&adapter->queue_lock);
965
966 return -EINVAL;
967 }
968
969 avail_queues->avail_rxq -= max_q->max_rxq;
970 avail_queues->avail_txq -= max_q->max_txq;
971 avail_queues->avail_bufq -= max_q->max_bufq;
972 avail_queues->avail_complq -= max_q->max_complq;
973
974 mutex_unlock(&adapter->queue_lock);
975
976 return 0;
977}
978
979/**
980 * idpf_vport_dealloc_max_qs - Deallocate max queues of a vport
981 * @adapter: Driver specific private structure
982 * @max_q: vport max queue structure
983 */
984void idpf_vport_dealloc_max_qs(struct idpf_adapter *adapter,
985 struct idpf_vport_max_q *max_q)
986{
987 struct idpf_avail_queue_info *avail_queues;
988
989 mutex_lock(&adapter->queue_lock);
990 avail_queues = &adapter->avail_queues;
991
992 avail_queues->avail_rxq += max_q->max_rxq;
993 avail_queues->avail_txq += max_q->max_txq;
994 avail_queues->avail_bufq += max_q->max_bufq;
995 avail_queues->avail_complq += max_q->max_complq;
996
997 mutex_unlock(&adapter->queue_lock);
998}
999
1000/**
1001 * idpf_init_avail_queues - Initialize available queues on the device
1002 * @adapter: Driver specific private structure
1003 */
1004static void idpf_init_avail_queues(struct idpf_adapter *adapter)
1005{
1006 struct idpf_avail_queue_info *avail_queues = &adapter->avail_queues;
1007 struct virtchnl2_get_capabilities *caps = &adapter->caps;
1008
1009 avail_queues->avail_rxq = le16_to_cpu(caps->max_rx_q);
1010 avail_queues->avail_txq = le16_to_cpu(caps->max_tx_q);
1011 avail_queues->avail_bufq = le16_to_cpu(caps->max_rx_bufq);
1012 avail_queues->avail_complq = le16_to_cpu(caps->max_tx_complq);
1013}
1014
1015/**
1016 * idpf_get_reg_intr_vecs - Get vector queue register offset
1017 * @vport: virtual port structure
1018 * @reg_vals: Register offsets to store in
1019 *
1020 * Returns number of registers that got populated
1021 */
1022int idpf_get_reg_intr_vecs(struct idpf_vport *vport,
1023 struct idpf_vec_regs *reg_vals)
1024{
1025 struct virtchnl2_vector_chunks *chunks;
1026 struct idpf_vec_regs reg_val;
1027 u16 num_vchunks, num_vec;
1028 int num_regs = 0, i, j;
1029
1030 chunks = &vport->adapter->req_vec_chunks->vchunks;
1031 num_vchunks = le16_to_cpu(chunks->num_vchunks);
1032
1033 for (j = 0; j < num_vchunks; j++) {
1034 struct virtchnl2_vector_chunk *chunk;
1035 u32 dynctl_reg_spacing;
1036 u32 itrn_reg_spacing;
1037
1038 chunk = &chunks->vchunks[j];
1039 num_vec = le16_to_cpu(chunk->num_vectors);
1040 reg_val.dyn_ctl_reg = le32_to_cpu(chunk->dynctl_reg_start);
1041 reg_val.itrn_reg = le32_to_cpu(chunk->itrn_reg_start);
1042 reg_val.itrn_index_spacing = le32_to_cpu(chunk->itrn_index_spacing);
1043
1044 dynctl_reg_spacing = le32_to_cpu(chunk->dynctl_reg_spacing);
1045 itrn_reg_spacing = le32_to_cpu(chunk->itrn_reg_spacing);
1046
1047 for (i = 0; i < num_vec; i++) {
1048 reg_vals[num_regs].dyn_ctl_reg = reg_val.dyn_ctl_reg;
1049 reg_vals[num_regs].itrn_reg = reg_val.itrn_reg;
1050 reg_vals[num_regs].itrn_index_spacing =
1051 reg_val.itrn_index_spacing;
1052
1053 reg_val.dyn_ctl_reg += dynctl_reg_spacing;
1054 reg_val.itrn_reg += itrn_reg_spacing;
1055 num_regs++;
1056 }
1057 }
1058
1059 return num_regs;
1060}
1061
1062/**
1063 * idpf_vport_get_q_reg - Get the queue registers for the vport
1064 * @reg_vals: register values needing to be set
1065 * @num_regs: amount we expect to fill
1066 * @q_type: queue model
1067 * @chunks: queue regs received over mailbox
1068 *
1069 * This function parses the queue register offsets from the queue register
1070 * chunk information, with a specific queue type and stores it into the array
1071 * passed as an argument. It returns the actual number of queue registers that
1072 * are filled.
1073 */
1074static int idpf_vport_get_q_reg(u32 *reg_vals, int num_regs, u32 q_type,
1075 struct virtchnl2_queue_reg_chunks *chunks)
1076{
1077 u16 num_chunks = le16_to_cpu(chunks->num_chunks);
1078 int reg_filled = 0, i;
1079 u32 reg_val;
1080
1081 while (num_chunks--) {
1082 struct virtchnl2_queue_reg_chunk *chunk;
1083 u16 num_q;
1084
1085 chunk = &chunks->chunks[num_chunks];
1086 if (le32_to_cpu(chunk->type) != q_type)
1087 continue;
1088
1089 num_q = le32_to_cpu(chunk->num_queues);
1090 reg_val = le64_to_cpu(chunk->qtail_reg_start);
1091 for (i = 0; i < num_q && reg_filled < num_regs ; i++) {
1092 reg_vals[reg_filled++] = reg_val;
1093 reg_val += le32_to_cpu(chunk->qtail_reg_spacing);
1094 }
1095 }
1096
1097 return reg_filled;
1098}
1099
1100/**
1101 * __idpf_queue_reg_init - initialize queue registers
1102 * @vport: virtual port structure
1103 * @reg_vals: registers we are initializing
1104 * @num_regs: how many registers there are in total
1105 * @q_type: queue model
1106 *
1107 * Return number of queues that are initialized
1108 */
1109static int __idpf_queue_reg_init(struct idpf_vport *vport, u32 *reg_vals,
1110 int num_regs, u32 q_type)
1111{
1112 struct idpf_adapter *adapter = vport->adapter;
1113 struct idpf_queue *q;
1114 int i, j, k = 0;
1115
1116 switch (q_type) {
1117 case VIRTCHNL2_QUEUE_TYPE_TX:
1118 for (i = 0; i < vport->num_txq_grp; i++) {
1119 struct idpf_txq_group *tx_qgrp = &vport->txq_grps[i];
1120
1121 for (j = 0; j < tx_qgrp->num_txq && k < num_regs; j++, k++)
1122 tx_qgrp->txqs[j]->tail =
1123 idpf_get_reg_addr(adapter, reg_vals[k]);
1124 }
1125 break;
1126 case VIRTCHNL2_QUEUE_TYPE_RX:
1127 for (i = 0; i < vport->num_rxq_grp; i++) {
1128 struct idpf_rxq_group *rx_qgrp = &vport->rxq_grps[i];
1129 u16 num_rxq = rx_qgrp->singleq.num_rxq;
1130
1131 for (j = 0; j < num_rxq && k < num_regs; j++, k++) {
1132 q = rx_qgrp->singleq.rxqs[j];
1133 q->tail = idpf_get_reg_addr(adapter,
1134 reg_vals[k]);
1135 }
1136 }
1137 break;
1138 case VIRTCHNL2_QUEUE_TYPE_RX_BUFFER:
1139 for (i = 0; i < vport->num_rxq_grp; i++) {
1140 struct idpf_rxq_group *rx_qgrp = &vport->rxq_grps[i];
1141 u8 num_bufqs = vport->num_bufqs_per_qgrp;
1142
1143 for (j = 0; j < num_bufqs && k < num_regs; j++, k++) {
1144 q = &rx_qgrp->splitq.bufq_sets[j].bufq;
1145 q->tail = idpf_get_reg_addr(adapter,
1146 reg_vals[k]);
1147 }
1148 }
1149 break;
1150 default:
1151 break;
1152 }
1153
1154 return k;
1155}
1156
1157/**
1158 * idpf_queue_reg_init - initialize queue registers
1159 * @vport: virtual port structure
1160 *
1161 * Return 0 on success, negative on failure
1162 */
1163int idpf_queue_reg_init(struct idpf_vport *vport)
1164{
1165 struct virtchnl2_create_vport *vport_params;
1166 struct virtchnl2_queue_reg_chunks *chunks;
1167 struct idpf_vport_config *vport_config;
1168 u16 vport_idx = vport->idx;
1169 int num_regs, ret = 0;
1170 u32 *reg_vals;
1171
1172 /* We may never deal with more than 256 same type of queues */
1173 reg_vals = kzalloc(sizeof(void *) * IDPF_LARGE_MAX_Q, GFP_KERNEL);
1174 if (!reg_vals)
1175 return -ENOMEM;
1176
1177 vport_config = vport->adapter->vport_config[vport_idx];
1178 if (vport_config->req_qs_chunks) {
1179 struct virtchnl2_add_queues *vc_aq =
1180 (struct virtchnl2_add_queues *)vport_config->req_qs_chunks;
1181 chunks = &vc_aq->chunks;
1182 } else {
1183 vport_params = vport->adapter->vport_params_recvd[vport_idx];
1184 chunks = &vport_params->chunks;
1185 }
1186
1187 /* Initialize Tx queue tail register address */
1188 num_regs = idpf_vport_get_q_reg(reg_vals, IDPF_LARGE_MAX_Q,
1189 VIRTCHNL2_QUEUE_TYPE_TX,
1190 chunks);
1191 if (num_regs < vport->num_txq) {
1192 ret = -EINVAL;
1193 goto free_reg_vals;
1194 }
1195
1196 num_regs = __idpf_queue_reg_init(vport, reg_vals, num_regs,
1197 VIRTCHNL2_QUEUE_TYPE_TX);
1198 if (num_regs < vport->num_txq) {
1199 ret = -EINVAL;
1200 goto free_reg_vals;
1201 }
1202
1203 /* Initialize Rx/buffer queue tail register address based on Rx queue
1204 * model
1205 */
1206 if (idpf_is_queue_model_split(vport->rxq_model)) {
1207 num_regs = idpf_vport_get_q_reg(reg_vals, IDPF_LARGE_MAX_Q,
1208 VIRTCHNL2_QUEUE_TYPE_RX_BUFFER,
1209 chunks);
1210 if (num_regs < vport->num_bufq) {
1211 ret = -EINVAL;
1212 goto free_reg_vals;
1213 }
1214
1215 num_regs = __idpf_queue_reg_init(vport, reg_vals, num_regs,
1216 VIRTCHNL2_QUEUE_TYPE_RX_BUFFER);
1217 if (num_regs < vport->num_bufq) {
1218 ret = -EINVAL;
1219 goto free_reg_vals;
1220 }
1221 } else {
1222 num_regs = idpf_vport_get_q_reg(reg_vals, IDPF_LARGE_MAX_Q,
1223 VIRTCHNL2_QUEUE_TYPE_RX,
1224 chunks);
1225 if (num_regs < vport->num_rxq) {
1226 ret = -EINVAL;
1227 goto free_reg_vals;
1228 }
1229
1230 num_regs = __idpf_queue_reg_init(vport, reg_vals, num_regs,
1231 VIRTCHNL2_QUEUE_TYPE_RX);
1232 if (num_regs < vport->num_rxq) {
1233 ret = -EINVAL;
1234 goto free_reg_vals;
1235 }
1236 }
1237
1238free_reg_vals:
1239 kfree(reg_vals);
1240
1241 return ret;
1242}
1243
1244/**
1245 * idpf_send_create_vport_msg - Send virtchnl create vport message
1246 * @adapter: Driver specific private structure
1247 * @max_q: vport max queue info
1248 *
1249 * send virtchnl creae vport message
1250 *
1251 * Returns 0 on success, negative on failure
1252 */
1253int idpf_send_create_vport_msg(struct idpf_adapter *adapter,
1254 struct idpf_vport_max_q *max_q)
1255{
1256 struct virtchnl2_create_vport *vport_msg;
1257 u16 idx = adapter->next_vport;
1258 int err, buf_size;
1259
1260 buf_size = sizeof(struct virtchnl2_create_vport);
1261 if (!adapter->vport_params_reqd[idx]) {
1262 adapter->vport_params_reqd[idx] = kzalloc(buf_size,
1263 GFP_KERNEL);
1264 if (!adapter->vport_params_reqd[idx])
1265 return -ENOMEM;
1266 }
1267
1268 vport_msg = adapter->vport_params_reqd[idx];
1269 vport_msg->vport_type = cpu_to_le16(VIRTCHNL2_VPORT_TYPE_DEFAULT);
1270 vport_msg->vport_index = cpu_to_le16(idx);
1271
1272 if (adapter->req_tx_splitq)
1273 vport_msg->txq_model = cpu_to_le16(VIRTCHNL2_QUEUE_MODEL_SPLIT);
1274 else
1275 vport_msg->txq_model = cpu_to_le16(VIRTCHNL2_QUEUE_MODEL_SINGLE);
1276
1277 if (adapter->req_rx_splitq)
1278 vport_msg->rxq_model = cpu_to_le16(VIRTCHNL2_QUEUE_MODEL_SPLIT);
1279 else
1280 vport_msg->rxq_model = cpu_to_le16(VIRTCHNL2_QUEUE_MODEL_SINGLE);
1281
1282 err = idpf_vport_calc_total_qs(adapter, idx, vport_msg, max_q);
1283 if (err) {
1284 dev_err(&adapter->pdev->dev, "Enough queues are not available");
1285
1286 return err;
1287 }
1288
1289 mutex_lock(&adapter->vc_buf_lock);
1290
1291 err = idpf_send_mb_msg(adapter, VIRTCHNL2_OP_CREATE_VPORT, buf_size,
1292 (u8 *)vport_msg);
1293 if (err)
1294 goto rel_lock;
1295
1296 err = idpf_wait_for_event(adapter, NULL, IDPF_VC_CREATE_VPORT,
1297 IDPF_VC_CREATE_VPORT_ERR);
1298 if (err) {
1299 dev_err(&adapter->pdev->dev, "Failed to receive create vport message");
1300
1301 goto rel_lock;
1302 }
1303
1304 if (!adapter->vport_params_recvd[idx]) {
1305 adapter->vport_params_recvd[idx] = kzalloc(IDPF_CTLQ_MAX_BUF_LEN,
1306 GFP_KERNEL);
1307 if (!adapter->vport_params_recvd[idx]) {
1308 err = -ENOMEM;
1309 goto rel_lock;
1310 }
1311 }
1312
1313 vport_msg = adapter->vport_params_recvd[idx];
1314 memcpy(vport_msg, adapter->vc_msg, IDPF_CTLQ_MAX_BUF_LEN);
1315
1316rel_lock:
1317 mutex_unlock(&adapter->vc_buf_lock);
1318
1319 return err;
1320}
1321
1322/**
1323 * idpf_check_supported_desc_ids - Verify we have required descriptor support
1324 * @vport: virtual port structure
1325 *
1326 * Return 0 on success, error on failure
1327 */
1328int idpf_check_supported_desc_ids(struct idpf_vport *vport)
1329{
1330 struct idpf_adapter *adapter = vport->adapter;
1331 struct virtchnl2_create_vport *vport_msg;
1332 u64 rx_desc_ids, tx_desc_ids;
1333
1334 vport_msg = adapter->vport_params_recvd[vport->idx];
1335
1336 rx_desc_ids = le64_to_cpu(vport_msg->rx_desc_ids);
1337 tx_desc_ids = le64_to_cpu(vport_msg->tx_desc_ids);
1338
1339 if (vport->rxq_model == VIRTCHNL2_QUEUE_MODEL_SPLIT) {
1340 if (!(rx_desc_ids & VIRTCHNL2_RXDID_2_FLEX_SPLITQ_M)) {
1341 dev_info(&adapter->pdev->dev, "Minimum RX descriptor support not provided, using the default\n");
1342 vport_msg->rx_desc_ids = cpu_to_le64(VIRTCHNL2_RXDID_2_FLEX_SPLITQ_M);
1343 }
1344 } else {
1345 if (!(rx_desc_ids & VIRTCHNL2_RXDID_2_FLEX_SQ_NIC_M))
1346 vport->base_rxd = true;
1347 }
1348
1349 if (vport->txq_model != VIRTCHNL2_QUEUE_MODEL_SPLIT)
1350 return 0;
1351
1352 if ((tx_desc_ids & MIN_SUPPORT_TXDID) != MIN_SUPPORT_TXDID) {
1353 dev_info(&adapter->pdev->dev, "Minimum TX descriptor support not provided, using the default\n");
1354 vport_msg->tx_desc_ids = cpu_to_le64(MIN_SUPPORT_TXDID);
1355 }
1356
1357 return 0;
1358}
1359
1360/**
1361 * idpf_send_destroy_vport_msg - Send virtchnl destroy vport message
1362 * @vport: virtual port data structure
1363 *
1364 * Send virtchnl destroy vport message. Returns 0 on success, negative on
1365 * failure.
1366 */
1367int idpf_send_destroy_vport_msg(struct idpf_vport *vport)
1368{
1369 struct idpf_adapter *adapter = vport->adapter;
1370 struct virtchnl2_vport v_id;
1371 int err;
1372
1373 v_id.vport_id = cpu_to_le32(vport->vport_id);
1374
1375 mutex_lock(&vport->vc_buf_lock);
1376
1377 err = idpf_send_mb_msg(adapter, VIRTCHNL2_OP_DESTROY_VPORT,
1378 sizeof(v_id), (u8 *)&v_id);
1379 if (err)
1380 goto rel_lock;
1381
1382 err = idpf_min_wait_for_event(adapter, vport, IDPF_VC_DESTROY_VPORT,
1383 IDPF_VC_DESTROY_VPORT_ERR);
1384
1385rel_lock:
1386 mutex_unlock(&vport->vc_buf_lock);
1387
1388 return err;
1389}
1390
1391/**
1392 * idpf_send_enable_vport_msg - Send virtchnl enable vport message
1393 * @vport: virtual port data structure
1394 *
1395 * Send enable vport virtchnl message. Returns 0 on success, negative on
1396 * failure.
1397 */
1398int idpf_send_enable_vport_msg(struct idpf_vport *vport)
1399{
1400 struct idpf_adapter *adapter = vport->adapter;
1401 struct virtchnl2_vport v_id;
1402 int err;
1403
1404 v_id.vport_id = cpu_to_le32(vport->vport_id);
1405
1406 mutex_lock(&vport->vc_buf_lock);
1407
1408 err = idpf_send_mb_msg(adapter, VIRTCHNL2_OP_ENABLE_VPORT,
1409 sizeof(v_id), (u8 *)&v_id);
1410 if (err)
1411 goto rel_lock;
1412
1413 err = idpf_wait_for_event(adapter, vport, IDPF_VC_ENA_VPORT,
1414 IDPF_VC_ENA_VPORT_ERR);
1415
1416rel_lock:
1417 mutex_unlock(&vport->vc_buf_lock);
1418
1419 return err;
1420}
1421
1422/**
1423 * idpf_send_disable_vport_msg - Send virtchnl disable vport message
1424 * @vport: virtual port data structure
1425 *
1426 * Send disable vport virtchnl message. Returns 0 on success, negative on
1427 * failure.
1428 */
1429int idpf_send_disable_vport_msg(struct idpf_vport *vport)
1430{
1431 struct idpf_adapter *adapter = vport->adapter;
1432 struct virtchnl2_vport v_id;
1433 int err;
1434
1435 v_id.vport_id = cpu_to_le32(vport->vport_id);
1436
1437 mutex_lock(&vport->vc_buf_lock);
1438
1439 err = idpf_send_mb_msg(adapter, VIRTCHNL2_OP_DISABLE_VPORT,
1440 sizeof(v_id), (u8 *)&v_id);
1441 if (err)
1442 goto rel_lock;
1443
1444 err = idpf_min_wait_for_event(adapter, vport, IDPF_VC_DIS_VPORT,
1445 IDPF_VC_DIS_VPORT_ERR);
1446
1447rel_lock:
1448 mutex_unlock(&vport->vc_buf_lock);
1449
1450 return err;
1451}
1452
1453/**
1454 * idpf_send_config_tx_queues_msg - Send virtchnl config tx queues message
1455 * @vport: virtual port data structure
1456 *
1457 * Send config tx queues virtchnl message. Returns 0 on success, negative on
1458 * failure.
1459 */
1460static int idpf_send_config_tx_queues_msg(struct idpf_vport *vport)
1461{
1462 struct virtchnl2_config_tx_queues *ctq;
1463 u32 config_sz, chunk_sz, buf_sz;
1464 int totqs, num_msgs, num_chunks;
1465 struct virtchnl2_txq_info *qi;
1466 int err = 0, i, k = 0;
1467
1468 totqs = vport->num_txq + vport->num_complq;
1469 qi = kcalloc(totqs, sizeof(struct virtchnl2_txq_info), GFP_KERNEL);
1470 if (!qi)
1471 return -ENOMEM;
1472
1473 /* Populate the queue info buffer with all queue context info */
1474 for (i = 0; i < vport->num_txq_grp; i++) {
1475 struct idpf_txq_group *tx_qgrp = &vport->txq_grps[i];
1476 int j, sched_mode;
1477
1478 for (j = 0; j < tx_qgrp->num_txq; j++, k++) {
1479 qi[k].queue_id =
1480 cpu_to_le32(tx_qgrp->txqs[j]->q_id);
1481 qi[k].model =
1482 cpu_to_le16(vport->txq_model);
1483 qi[k].type =
1484 cpu_to_le32(tx_qgrp->txqs[j]->q_type);
1485 qi[k].ring_len =
1486 cpu_to_le16(tx_qgrp->txqs[j]->desc_count);
1487 qi[k].dma_ring_addr =
1488 cpu_to_le64(tx_qgrp->txqs[j]->dma);
1489 if (idpf_is_queue_model_split(vport->txq_model)) {
1490 struct idpf_queue *q = tx_qgrp->txqs[j];
1491
1492 qi[k].tx_compl_queue_id =
1493 cpu_to_le16(tx_qgrp->complq->q_id);
1494 qi[k].relative_queue_id = cpu_to_le16(j);
1495
1496 if (test_bit(__IDPF_Q_FLOW_SCH_EN, q->flags))
1497 qi[k].sched_mode =
1498 cpu_to_le16(VIRTCHNL2_TXQ_SCHED_MODE_FLOW);
1499 else
1500 qi[k].sched_mode =
1501 cpu_to_le16(VIRTCHNL2_TXQ_SCHED_MODE_QUEUE);
1502 } else {
1503 qi[k].sched_mode =
1504 cpu_to_le16(VIRTCHNL2_TXQ_SCHED_MODE_QUEUE);
1505 }
1506 }
1507
1508 if (!idpf_is_queue_model_split(vport->txq_model))
1509 continue;
1510
1511 qi[k].queue_id = cpu_to_le32(tx_qgrp->complq->q_id);
1512 qi[k].model = cpu_to_le16(vport->txq_model);
1513 qi[k].type = cpu_to_le32(tx_qgrp->complq->q_type);
1514 qi[k].ring_len = cpu_to_le16(tx_qgrp->complq->desc_count);
1515 qi[k].dma_ring_addr = cpu_to_le64(tx_qgrp->complq->dma);
1516
1517 if (test_bit(__IDPF_Q_FLOW_SCH_EN, tx_qgrp->complq->flags))
1518 sched_mode = VIRTCHNL2_TXQ_SCHED_MODE_FLOW;
1519 else
1520 sched_mode = VIRTCHNL2_TXQ_SCHED_MODE_QUEUE;
1521 qi[k].sched_mode = cpu_to_le16(sched_mode);
1522
1523 k++;
1524 }
1525
1526 /* Make sure accounting agrees */
1527 if (k != totqs) {
1528 err = -EINVAL;
1529 goto error;
1530 }
1531
1532 /* Chunk up the queue contexts into multiple messages to avoid
1533 * sending a control queue message buffer that is too large
1534 */
1535 config_sz = sizeof(struct virtchnl2_config_tx_queues);
1536 chunk_sz = sizeof(struct virtchnl2_txq_info);
1537
1538 num_chunks = min_t(u32, IDPF_NUM_CHUNKS_PER_MSG(config_sz, chunk_sz),
1539 totqs);
1540 num_msgs = DIV_ROUND_UP(totqs, num_chunks);
1541
1542 buf_sz = struct_size(ctq, qinfo, num_chunks);
1543 ctq = kzalloc(buf_sz, GFP_KERNEL);
1544 if (!ctq) {
1545 err = -ENOMEM;
1546 goto error;
1547 }
1548
1549 mutex_lock(&vport->vc_buf_lock);
1550
1551 for (i = 0, k = 0; i < num_msgs; i++) {
1552 memset(ctq, 0, buf_sz);
1553 ctq->vport_id = cpu_to_le32(vport->vport_id);
1554 ctq->num_qinfo = cpu_to_le16(num_chunks);
1555 memcpy(ctq->qinfo, &qi[k], chunk_sz * num_chunks);
1556
1557 err = idpf_send_mb_msg(vport->adapter,
1558 VIRTCHNL2_OP_CONFIG_TX_QUEUES,
1559 buf_sz, (u8 *)ctq);
1560 if (err)
1561 goto mbx_error;
1562
1563 err = idpf_wait_for_event(vport->adapter, vport,
1564 IDPF_VC_CONFIG_TXQ,
1565 IDPF_VC_CONFIG_TXQ_ERR);
1566 if (err)
1567 goto mbx_error;
1568
1569 k += num_chunks;
1570 totqs -= num_chunks;
1571 num_chunks = min(num_chunks, totqs);
1572 /* Recalculate buffer size */
1573 buf_sz = struct_size(ctq, qinfo, num_chunks);
1574 }
1575
1576mbx_error:
1577 mutex_unlock(&vport->vc_buf_lock);
1578 kfree(ctq);
1579error:
1580 kfree(qi);
1581
1582 return err;
1583}
1584
1585/**
1586 * idpf_send_config_rx_queues_msg - Send virtchnl config rx queues message
1587 * @vport: virtual port data structure
1588 *
1589 * Send config rx queues virtchnl message. Returns 0 on success, negative on
1590 * failure.
1591 */
1592static int idpf_send_config_rx_queues_msg(struct idpf_vport *vport)
1593{
1594 struct virtchnl2_config_rx_queues *crq;
1595 u32 config_sz, chunk_sz, buf_sz;
1596 int totqs, num_msgs, num_chunks;
1597 struct virtchnl2_rxq_info *qi;
1598 int err = 0, i, k = 0;
1599
1600 totqs = vport->num_rxq + vport->num_bufq;
1601 qi = kcalloc(totqs, sizeof(struct virtchnl2_rxq_info), GFP_KERNEL);
1602 if (!qi)
1603 return -ENOMEM;
1604
1605 /* Populate the queue info buffer with all queue context info */
1606 for (i = 0; i < vport->num_rxq_grp; i++) {
1607 struct idpf_rxq_group *rx_qgrp = &vport->rxq_grps[i];
1608 u16 num_rxq;
1609 int j;
1610
1611 if (!idpf_is_queue_model_split(vport->rxq_model))
1612 goto setup_rxqs;
1613
1614 for (j = 0; j < vport->num_bufqs_per_qgrp; j++, k++) {
1615 struct idpf_queue *bufq =
1616 &rx_qgrp->splitq.bufq_sets[j].bufq;
1617
1618 qi[k].queue_id = cpu_to_le32(bufq->q_id);
1619 qi[k].model = cpu_to_le16(vport->rxq_model);
1620 qi[k].type = cpu_to_le32(bufq->q_type);
1621 qi[k].desc_ids = cpu_to_le64(VIRTCHNL2_RXDID_2_FLEX_SPLITQ_M);
1622 qi[k].ring_len = cpu_to_le16(bufq->desc_count);
1623 qi[k].dma_ring_addr = cpu_to_le64(bufq->dma);
1624 qi[k].data_buffer_size = cpu_to_le32(bufq->rx_buf_size);
1625 qi[k].buffer_notif_stride = bufq->rx_buf_stride;
1626 qi[k].rx_buffer_low_watermark =
1627 cpu_to_le16(bufq->rx_buffer_low_watermark);
1628 if (idpf_is_feature_ena(vport, NETIF_F_GRO_HW))
1629 qi[k].qflags |= cpu_to_le16(VIRTCHNL2_RXQ_RSC);
1630 }
1631
1632setup_rxqs:
1633 if (idpf_is_queue_model_split(vport->rxq_model))
1634 num_rxq = rx_qgrp->splitq.num_rxq_sets;
1635 else
1636 num_rxq = rx_qgrp->singleq.num_rxq;
1637
1638 for (j = 0; j < num_rxq; j++, k++) {
1639 struct idpf_queue *rxq;
1640
1641 if (!idpf_is_queue_model_split(vport->rxq_model)) {
1642 rxq = rx_qgrp->singleq.rxqs[j];
1643 goto common_qi_fields;
1644 }
1645 rxq = &rx_qgrp->splitq.rxq_sets[j]->rxq;
1646 qi[k].rx_bufq1_id =
1647 cpu_to_le16(rxq->rxq_grp->splitq.bufq_sets[0].bufq.q_id);
1648 if (vport->num_bufqs_per_qgrp > IDPF_SINGLE_BUFQ_PER_RXQ_GRP) {
1649 qi[k].bufq2_ena = IDPF_BUFQ2_ENA;
1650 qi[k].rx_bufq2_id =
1651 cpu_to_le16(rxq->rxq_grp->splitq.bufq_sets[1].bufq.q_id);
1652 }
1653 qi[k].rx_buffer_low_watermark =
1654 cpu_to_le16(rxq->rx_buffer_low_watermark);
1655 if (idpf_is_feature_ena(vport, NETIF_F_GRO_HW))
1656 qi[k].qflags |= cpu_to_le16(VIRTCHNL2_RXQ_RSC);
1657
1658common_qi_fields:
1659 if (rxq->rx_hsplit_en) {
1660 qi[k].qflags |=
1661 cpu_to_le16(VIRTCHNL2_RXQ_HDR_SPLIT);
1662 qi[k].hdr_buffer_size =
1663 cpu_to_le16(rxq->rx_hbuf_size);
1664 }
1665 qi[k].queue_id = cpu_to_le32(rxq->q_id);
1666 qi[k].model = cpu_to_le16(vport->rxq_model);
1667 qi[k].type = cpu_to_le32(rxq->q_type);
1668 qi[k].ring_len = cpu_to_le16(rxq->desc_count);
1669 qi[k].dma_ring_addr = cpu_to_le64(rxq->dma);
1670 qi[k].max_pkt_size = cpu_to_le32(rxq->rx_max_pkt_size);
1671 qi[k].data_buffer_size = cpu_to_le32(rxq->rx_buf_size);
1672 qi[k].qflags |=
1673 cpu_to_le16(VIRTCHNL2_RX_DESC_SIZE_32BYTE);
1674 qi[k].desc_ids = cpu_to_le64(rxq->rxdids);
1675 }
1676 }
1677
1678 /* Make sure accounting agrees */
1679 if (k != totqs) {
1680 err = -EINVAL;
1681 goto error;
1682 }
1683
1684 /* Chunk up the queue contexts into multiple messages to avoid
1685 * sending a control queue message buffer that is too large
1686 */
1687 config_sz = sizeof(struct virtchnl2_config_rx_queues);
1688 chunk_sz = sizeof(struct virtchnl2_rxq_info);
1689
1690 num_chunks = min_t(u32, IDPF_NUM_CHUNKS_PER_MSG(config_sz, chunk_sz),
1691 totqs);
1692 num_msgs = DIV_ROUND_UP(totqs, num_chunks);
1693
1694 buf_sz = struct_size(crq, qinfo, num_chunks);
1695 crq = kzalloc(buf_sz, GFP_KERNEL);
1696 if (!crq) {
1697 err = -ENOMEM;
1698 goto error;
1699 }
1700
1701 mutex_lock(&vport->vc_buf_lock);
1702
1703 for (i = 0, k = 0; i < num_msgs; i++) {
1704 memset(crq, 0, buf_sz);
1705 crq->vport_id = cpu_to_le32(vport->vport_id);
1706 crq->num_qinfo = cpu_to_le16(num_chunks);
1707 memcpy(crq->qinfo, &qi[k], chunk_sz * num_chunks);
1708
1709 err = idpf_send_mb_msg(vport->adapter,
1710 VIRTCHNL2_OP_CONFIG_RX_QUEUES,
1711 buf_sz, (u8 *)crq);
1712 if (err)
1713 goto mbx_error;
1714
1715 err = idpf_wait_for_event(vport->adapter, vport,
1716 IDPF_VC_CONFIG_RXQ,
1717 IDPF_VC_CONFIG_RXQ_ERR);
1718 if (err)
1719 goto mbx_error;
1720
1721 k += num_chunks;
1722 totqs -= num_chunks;
1723 num_chunks = min(num_chunks, totqs);
1724 /* Recalculate buffer size */
1725 buf_sz = struct_size(crq, qinfo, num_chunks);
1726 }
1727
1728mbx_error:
1729 mutex_unlock(&vport->vc_buf_lock);
1730 kfree(crq);
1731error:
1732 kfree(qi);
1733
1734 return err;
1735}
1736
1737/**
1738 * idpf_send_ena_dis_queues_msg - Send virtchnl enable or disable
1739 * queues message
1740 * @vport: virtual port data structure
1741 * @vc_op: virtchnl op code to send
1742 *
1743 * Send enable or disable queues virtchnl message. Returns 0 on success,
1744 * negative on failure.
1745 */
1746static int idpf_send_ena_dis_queues_msg(struct idpf_vport *vport, u32 vc_op)
1747{
1748 u32 num_msgs, num_chunks, num_txq, num_rxq, num_q;
1749 struct idpf_adapter *adapter = vport->adapter;
1750 struct virtchnl2_del_ena_dis_queues *eq;
1751 struct virtchnl2_queue_chunks *qcs;
1752 struct virtchnl2_queue_chunk *qc;
1753 u32 config_sz, chunk_sz, buf_sz;
1754 int i, j, k = 0, err = 0;
1755
1756 /* validate virtchnl op */
1757 switch (vc_op) {
1758 case VIRTCHNL2_OP_ENABLE_QUEUES:
1759 case VIRTCHNL2_OP_DISABLE_QUEUES:
1760 break;
1761 default:
1762 return -EINVAL;
1763 }
1764
1765 num_txq = vport->num_txq + vport->num_complq;
1766 num_rxq = vport->num_rxq + vport->num_bufq;
1767 num_q = num_txq + num_rxq;
1768 buf_sz = sizeof(struct virtchnl2_queue_chunk) * num_q;
1769 qc = kzalloc(buf_sz, GFP_KERNEL);
1770 if (!qc)
1771 return -ENOMEM;
1772
1773 for (i = 0; i < vport->num_txq_grp; i++) {
1774 struct idpf_txq_group *tx_qgrp = &vport->txq_grps[i];
1775
1776 for (j = 0; j < tx_qgrp->num_txq; j++, k++) {
1777 qc[k].type = cpu_to_le32(tx_qgrp->txqs[j]->q_type);
1778 qc[k].start_queue_id = cpu_to_le32(tx_qgrp->txqs[j]->q_id);
1779 qc[k].num_queues = cpu_to_le32(IDPF_NUMQ_PER_CHUNK);
1780 }
1781 }
1782 if (vport->num_txq != k) {
1783 err = -EINVAL;
1784 goto error;
1785 }
1786
1787 if (!idpf_is_queue_model_split(vport->txq_model))
1788 goto setup_rx;
1789
1790 for (i = 0; i < vport->num_txq_grp; i++, k++) {
1791 struct idpf_txq_group *tx_qgrp = &vport->txq_grps[i];
1792
1793 qc[k].type = cpu_to_le32(tx_qgrp->complq->q_type);
1794 qc[k].start_queue_id = cpu_to_le32(tx_qgrp->complq->q_id);
1795 qc[k].num_queues = cpu_to_le32(IDPF_NUMQ_PER_CHUNK);
1796 }
1797 if (vport->num_complq != (k - vport->num_txq)) {
1798 err = -EINVAL;
1799 goto error;
1800 }
1801
1802setup_rx:
1803 for (i = 0; i < vport->num_rxq_grp; i++) {
1804 struct idpf_rxq_group *rx_qgrp = &vport->rxq_grps[i];
1805
1806 if (idpf_is_queue_model_split(vport->rxq_model))
1807 num_rxq = rx_qgrp->splitq.num_rxq_sets;
1808 else
1809 num_rxq = rx_qgrp->singleq.num_rxq;
1810
1811 for (j = 0; j < num_rxq; j++, k++) {
1812 if (idpf_is_queue_model_split(vport->rxq_model)) {
1813 qc[k].start_queue_id =
1814 cpu_to_le32(rx_qgrp->splitq.rxq_sets[j]->rxq.q_id);
1815 qc[k].type =
1816 cpu_to_le32(rx_qgrp->splitq.rxq_sets[j]->rxq.q_type);
1817 } else {
1818 qc[k].start_queue_id =
1819 cpu_to_le32(rx_qgrp->singleq.rxqs[j]->q_id);
1820 qc[k].type =
1821 cpu_to_le32(rx_qgrp->singleq.rxqs[j]->q_type);
1822 }
1823 qc[k].num_queues = cpu_to_le32(IDPF_NUMQ_PER_CHUNK);
1824 }
1825 }
1826 if (vport->num_rxq != k - (vport->num_txq + vport->num_complq)) {
1827 err = -EINVAL;
1828 goto error;
1829 }
1830
1831 if (!idpf_is_queue_model_split(vport->rxq_model))
1832 goto send_msg;
1833
1834 for (i = 0; i < vport->num_rxq_grp; i++) {
1835 struct idpf_rxq_group *rx_qgrp = &vport->rxq_grps[i];
1836
1837 for (j = 0; j < vport->num_bufqs_per_qgrp; j++, k++) {
1838 struct idpf_queue *q;
1839
1840 q = &rx_qgrp->splitq.bufq_sets[j].bufq;
1841 qc[k].type = cpu_to_le32(q->q_type);
1842 qc[k].start_queue_id = cpu_to_le32(q->q_id);
1843 qc[k].num_queues = cpu_to_le32(IDPF_NUMQ_PER_CHUNK);
1844 }
1845 }
1846 if (vport->num_bufq != k - (vport->num_txq +
1847 vport->num_complq +
1848 vport->num_rxq)) {
1849 err = -EINVAL;
1850 goto error;
1851 }
1852
1853send_msg:
1854 /* Chunk up the queue info into multiple messages */
1855 config_sz = sizeof(struct virtchnl2_del_ena_dis_queues);
1856 chunk_sz = sizeof(struct virtchnl2_queue_chunk);
1857
1858 num_chunks = min_t(u32, IDPF_NUM_CHUNKS_PER_MSG(config_sz, chunk_sz),
1859 num_q);
1860 num_msgs = DIV_ROUND_UP(num_q, num_chunks);
1861
1862 buf_sz = struct_size(eq, chunks.chunks, num_chunks);
1863 eq = kzalloc(buf_sz, GFP_KERNEL);
1864 if (!eq) {
1865 err = -ENOMEM;
1866 goto error;
1867 }
1868
1869 mutex_lock(&vport->vc_buf_lock);
1870
1871 for (i = 0, k = 0; i < num_msgs; i++) {
1872 memset(eq, 0, buf_sz);
1873 eq->vport_id = cpu_to_le32(vport->vport_id);
1874 eq->chunks.num_chunks = cpu_to_le16(num_chunks);
1875 qcs = &eq->chunks;
1876 memcpy(qcs->chunks, &qc[k], chunk_sz * num_chunks);
1877
1878 err = idpf_send_mb_msg(adapter, vc_op, buf_sz, (u8 *)eq);
1879 if (err)
1880 goto mbx_error;
1881
1882 if (vc_op == VIRTCHNL2_OP_ENABLE_QUEUES)
1883 err = idpf_wait_for_event(adapter, vport,
1884 IDPF_VC_ENA_QUEUES,
1885 IDPF_VC_ENA_QUEUES_ERR);
1886 else
1887 err = idpf_min_wait_for_event(adapter, vport,
1888 IDPF_VC_DIS_QUEUES,
1889 IDPF_VC_DIS_QUEUES_ERR);
1890 if (err)
1891 goto mbx_error;
1892
1893 k += num_chunks;
1894 num_q -= num_chunks;
1895 num_chunks = min(num_chunks, num_q);
1896 /* Recalculate buffer size */
1897 buf_sz = struct_size(eq, chunks.chunks, num_chunks);
1898 }
1899
1900mbx_error:
1901 mutex_unlock(&vport->vc_buf_lock);
1902 kfree(eq);
1903error:
1904 kfree(qc);
1905
1906 return err;
1907}
1908
1909/**
1910 * idpf_send_map_unmap_queue_vector_msg - Send virtchnl map or unmap queue
1911 * vector message
1912 * @vport: virtual port data structure
1913 * @map: true for map and false for unmap
1914 *
1915 * Send map or unmap queue vector virtchnl message. Returns 0 on success,
1916 * negative on failure.
1917 */
1918int idpf_send_map_unmap_queue_vector_msg(struct idpf_vport *vport, bool map)
1919{
1920 struct idpf_adapter *adapter = vport->adapter;
1921 struct virtchnl2_queue_vector_maps *vqvm;
1922 struct virtchnl2_queue_vector *vqv;
1923 u32 config_sz, chunk_sz, buf_sz;
1924 u32 num_msgs, num_chunks, num_q;
1925 int i, j, k = 0, err = 0;
1926
1927 num_q = vport->num_txq + vport->num_rxq;
1928
1929 buf_sz = sizeof(struct virtchnl2_queue_vector) * num_q;
1930 vqv = kzalloc(buf_sz, GFP_KERNEL);
1931 if (!vqv)
1932 return -ENOMEM;
1933
1934 for (i = 0; i < vport->num_txq_grp; i++) {
1935 struct idpf_txq_group *tx_qgrp = &vport->txq_grps[i];
1936
1937 for (j = 0; j < tx_qgrp->num_txq; j++, k++) {
1938 vqv[k].queue_type = cpu_to_le32(tx_qgrp->txqs[j]->q_type);
1939 vqv[k].queue_id = cpu_to_le32(tx_qgrp->txqs[j]->q_id);
1940
1941 if (idpf_is_queue_model_split(vport->txq_model)) {
1942 vqv[k].vector_id =
1943 cpu_to_le16(tx_qgrp->complq->q_vector->v_idx);
1944 vqv[k].itr_idx =
1945 cpu_to_le32(tx_qgrp->complq->q_vector->tx_itr_idx);
1946 } else {
1947 vqv[k].vector_id =
1948 cpu_to_le16(tx_qgrp->txqs[j]->q_vector->v_idx);
1949 vqv[k].itr_idx =
1950 cpu_to_le32(tx_qgrp->txqs[j]->q_vector->tx_itr_idx);
1951 }
1952 }
1953 }
1954
1955 if (vport->num_txq != k) {
1956 err = -EINVAL;
1957 goto error;
1958 }
1959
1960 for (i = 0; i < vport->num_rxq_grp; i++) {
1961 struct idpf_rxq_group *rx_qgrp = &vport->rxq_grps[i];
1962 u16 num_rxq;
1963
1964 if (idpf_is_queue_model_split(vport->rxq_model))
1965 num_rxq = rx_qgrp->splitq.num_rxq_sets;
1966 else
1967 num_rxq = rx_qgrp->singleq.num_rxq;
1968
1969 for (j = 0; j < num_rxq; j++, k++) {
1970 struct idpf_queue *rxq;
1971
1972 if (idpf_is_queue_model_split(vport->rxq_model))
1973 rxq = &rx_qgrp->splitq.rxq_sets[j]->rxq;
1974 else
1975 rxq = rx_qgrp->singleq.rxqs[j];
1976
1977 vqv[k].queue_type = cpu_to_le32(rxq->q_type);
1978 vqv[k].queue_id = cpu_to_le32(rxq->q_id);
1979 vqv[k].vector_id = cpu_to_le16(rxq->q_vector->v_idx);
1980 vqv[k].itr_idx = cpu_to_le32(rxq->q_vector->rx_itr_idx);
1981 }
1982 }
1983
1984 if (idpf_is_queue_model_split(vport->txq_model)) {
1985 if (vport->num_rxq != k - vport->num_complq) {
1986 err = -EINVAL;
1987 goto error;
1988 }
1989 } else {
1990 if (vport->num_rxq != k - vport->num_txq) {
1991 err = -EINVAL;
1992 goto error;
1993 }
1994 }
1995
1996 /* Chunk up the vector info into multiple messages */
1997 config_sz = sizeof(struct virtchnl2_queue_vector_maps);
1998 chunk_sz = sizeof(struct virtchnl2_queue_vector);
1999
2000 num_chunks = min_t(u32, IDPF_NUM_CHUNKS_PER_MSG(config_sz, chunk_sz),
2001 num_q);
2002 num_msgs = DIV_ROUND_UP(num_q, num_chunks);
2003
2004 buf_sz = struct_size(vqvm, qv_maps, num_chunks);
2005 vqvm = kzalloc(buf_sz, GFP_KERNEL);
2006 if (!vqvm) {
2007 err = -ENOMEM;
2008 goto error;
2009 }
2010
2011 mutex_lock(&vport->vc_buf_lock);
2012
2013 for (i = 0, k = 0; i < num_msgs; i++) {
2014 memset(vqvm, 0, buf_sz);
2015 vqvm->vport_id = cpu_to_le32(vport->vport_id);
2016 vqvm->num_qv_maps = cpu_to_le16(num_chunks);
2017 memcpy(vqvm->qv_maps, &vqv[k], chunk_sz * num_chunks);
2018
2019 if (map) {
2020 err = idpf_send_mb_msg(adapter,
2021 VIRTCHNL2_OP_MAP_QUEUE_VECTOR,
2022 buf_sz, (u8 *)vqvm);
2023 if (!err)
2024 err = idpf_wait_for_event(adapter, vport,
2025 IDPF_VC_MAP_IRQ,
2026 IDPF_VC_MAP_IRQ_ERR);
2027 } else {
2028 err = idpf_send_mb_msg(adapter,
2029 VIRTCHNL2_OP_UNMAP_QUEUE_VECTOR,
2030 buf_sz, (u8 *)vqvm);
2031 if (!err)
2032 err =
2033 idpf_min_wait_for_event(adapter, vport,
2034 IDPF_VC_UNMAP_IRQ,
2035 IDPF_VC_UNMAP_IRQ_ERR);
2036 }
2037 if (err)
2038 goto mbx_error;
2039
2040 k += num_chunks;
2041 num_q -= num_chunks;
2042 num_chunks = min(num_chunks, num_q);
2043 /* Recalculate buffer size */
2044 buf_sz = struct_size(vqvm, qv_maps, num_chunks);
2045 }
2046
2047mbx_error:
2048 mutex_unlock(&vport->vc_buf_lock);
2049 kfree(vqvm);
2050error:
2051 kfree(vqv);
2052
2053 return err;
2054}
2055
2056/**
2057 * idpf_send_enable_queues_msg - send enable queues virtchnl message
2058 * @vport: Virtual port private data structure
2059 *
2060 * Will send enable queues virtchnl message. Returns 0 on success, negative on
2061 * failure.
2062 */
2063int idpf_send_enable_queues_msg(struct idpf_vport *vport)
2064{
2065 return idpf_send_ena_dis_queues_msg(vport, VIRTCHNL2_OP_ENABLE_QUEUES);
2066}
2067
2068/**
2069 * idpf_send_disable_queues_msg - send disable queues virtchnl message
2070 * @vport: Virtual port private data structure
2071 *
2072 * Will send disable queues virtchnl message. Returns 0 on success, negative
2073 * on failure.
2074 */
2075int idpf_send_disable_queues_msg(struct idpf_vport *vport)
2076{
2077 int err, i;
2078
2079 err = idpf_send_ena_dis_queues_msg(vport, VIRTCHNL2_OP_DISABLE_QUEUES);
2080 if (err)
2081 return err;
2082
2083 /* switch to poll mode as interrupts will be disabled after disable
2084 * queues virtchnl message is sent
2085 */
2086 for (i = 0; i < vport->num_txq; i++)
2087 set_bit(__IDPF_Q_POLL_MODE, vport->txqs[i]->flags);
2088
2089 /* schedule the napi to receive all the marker packets */
2090 local_bh_disable();
2091 for (i = 0; i < vport->num_q_vectors; i++)
2092 napi_schedule(&vport->q_vectors[i].napi);
2093 local_bh_enable();
2094
2095 return idpf_wait_for_marker_event(vport);
2096}
2097
2098/**
2099 * idpf_convert_reg_to_queue_chunks - Copy queue chunk information to the right
2100 * structure
2101 * @dchunks: Destination chunks to store data to
2102 * @schunks: Source chunks to copy data from
2103 * @num_chunks: number of chunks to copy
2104 */
2105static void idpf_convert_reg_to_queue_chunks(struct virtchnl2_queue_chunk *dchunks,
2106 struct virtchnl2_queue_reg_chunk *schunks,
2107 u16 num_chunks)
2108{
2109 u16 i;
2110
2111 for (i = 0; i < num_chunks; i++) {
2112 dchunks[i].type = schunks[i].type;
2113 dchunks[i].start_queue_id = schunks[i].start_queue_id;
2114 dchunks[i].num_queues = schunks[i].num_queues;
2115 }
2116}
2117
2118/**
2119 * idpf_send_delete_queues_msg - send delete queues virtchnl message
2120 * @vport: Virtual port private data structure
2121 *
2122 * Will send delete queues virtchnl message. Return 0 on success, negative on
2123 * failure.
2124 */
2125int idpf_send_delete_queues_msg(struct idpf_vport *vport)
2126{
2127 struct idpf_adapter *adapter = vport->adapter;
2128 struct virtchnl2_create_vport *vport_params;
2129 struct virtchnl2_queue_reg_chunks *chunks;
2130 struct virtchnl2_del_ena_dis_queues *eq;
2131 struct idpf_vport_config *vport_config;
2132 u16 vport_idx = vport->idx;
2133 int buf_size, err;
2134 u16 num_chunks;
2135
2136 vport_config = adapter->vport_config[vport_idx];
2137 if (vport_config->req_qs_chunks) {
2138 struct virtchnl2_add_queues *vc_aq =
2139 (struct virtchnl2_add_queues *)vport_config->req_qs_chunks;
2140 chunks = &vc_aq->chunks;
2141 } else {
2142 vport_params = adapter->vport_params_recvd[vport_idx];
2143 chunks = &vport_params->chunks;
2144 }
2145
2146 num_chunks = le16_to_cpu(chunks->num_chunks);
2147 buf_size = struct_size(eq, chunks.chunks, num_chunks);
2148
2149 eq = kzalloc(buf_size, GFP_KERNEL);
2150 if (!eq)
2151 return -ENOMEM;
2152
2153 eq->vport_id = cpu_to_le32(vport->vport_id);
2154 eq->chunks.num_chunks = cpu_to_le16(num_chunks);
2155
2156 idpf_convert_reg_to_queue_chunks(eq->chunks.chunks, chunks->chunks,
2157 num_chunks);
2158
2159 mutex_lock(&vport->vc_buf_lock);
2160
2161 err = idpf_send_mb_msg(adapter, VIRTCHNL2_OP_DEL_QUEUES,
2162 buf_size, (u8 *)eq);
2163 if (err)
2164 goto rel_lock;
2165
2166 err = idpf_min_wait_for_event(adapter, vport, IDPF_VC_DEL_QUEUES,
2167 IDPF_VC_DEL_QUEUES_ERR);
2168
2169rel_lock:
2170 mutex_unlock(&vport->vc_buf_lock);
2171 kfree(eq);
2172
2173 return err;
2174}
2175
2176/**
2177 * idpf_send_config_queues_msg - Send config queues virtchnl message
2178 * @vport: Virtual port private data structure
2179 *
2180 * Will send config queues virtchnl message. Returns 0 on success, negative on
2181 * failure.
2182 */
2183int idpf_send_config_queues_msg(struct idpf_vport *vport)
2184{
2185 int err;
2186
2187 err = idpf_send_config_tx_queues_msg(vport);
2188 if (err)
2189 return err;
2190
2191 return idpf_send_config_rx_queues_msg(vport);
2192}
2193
2194/**
2195 * idpf_send_add_queues_msg - Send virtchnl add queues message
2196 * @vport: Virtual port private data structure
2197 * @num_tx_q: number of transmit queues
2198 * @num_complq: number of transmit completion queues
2199 * @num_rx_q: number of receive queues
2200 * @num_rx_bufq: number of receive buffer queues
2201 *
2202 * Returns 0 on success, negative on failure. vport _MUST_ be const here as
2203 * we should not change any fields within vport itself in this function.
2204 */
2205int idpf_send_add_queues_msg(const struct idpf_vport *vport, u16 num_tx_q,
2206 u16 num_complq, u16 num_rx_q, u16 num_rx_bufq)
2207{
2208 struct idpf_adapter *adapter = vport->adapter;
2209 struct idpf_vport_config *vport_config;
2210 struct virtchnl2_add_queues aq = { };
2211 struct virtchnl2_add_queues *vc_msg;
2212 u16 vport_idx = vport->idx;
2213 int size, err;
2214
2215 vport_config = adapter->vport_config[vport_idx];
2216
2217 aq.vport_id = cpu_to_le32(vport->vport_id);
2218 aq.num_tx_q = cpu_to_le16(num_tx_q);
2219 aq.num_tx_complq = cpu_to_le16(num_complq);
2220 aq.num_rx_q = cpu_to_le16(num_rx_q);
2221 aq.num_rx_bufq = cpu_to_le16(num_rx_bufq);
2222
2223 mutex_lock(&((struct idpf_vport *)vport)->vc_buf_lock);
2224
2225 err = idpf_send_mb_msg(adapter, VIRTCHNL2_OP_ADD_QUEUES,
2226 sizeof(struct virtchnl2_add_queues), (u8 *)&aq);
2227 if (err)
2228 goto rel_lock;
2229
2230 /* We want vport to be const to prevent incidental code changes making
2231 * changes to the vport config. We're making a special exception here
2232 * to discard const to use the virtchnl.
2233 */
2234 err = idpf_wait_for_event(adapter, (struct idpf_vport *)vport,
2235 IDPF_VC_ADD_QUEUES, IDPF_VC_ADD_QUEUES_ERR);
2236 if (err)
2237 goto rel_lock;
2238
2239 kfree(vport_config->req_qs_chunks);
2240 vport_config->req_qs_chunks = NULL;
2241
2242 vc_msg = (struct virtchnl2_add_queues *)vport->vc_msg;
2243 /* compare vc_msg num queues with vport num queues */
2244 if (le16_to_cpu(vc_msg->num_tx_q) != num_tx_q ||
2245 le16_to_cpu(vc_msg->num_rx_q) != num_rx_q ||
2246 le16_to_cpu(vc_msg->num_tx_complq) != num_complq ||
2247 le16_to_cpu(vc_msg->num_rx_bufq) != num_rx_bufq) {
2248 err = -EINVAL;
2249 goto rel_lock;
2250 }
2251
2252 size = struct_size(vc_msg, chunks.chunks,
2253 le16_to_cpu(vc_msg->chunks.num_chunks));
2254 vport_config->req_qs_chunks = kmemdup(vc_msg, size, GFP_KERNEL);
2255 if (!vport_config->req_qs_chunks) {
2256 err = -ENOMEM;
2257 goto rel_lock;
2258 }
2259
2260rel_lock:
2261 mutex_unlock(&((struct idpf_vport *)vport)->vc_buf_lock);
2262
2263 return err;
2264}
2265
2266/**
2267 * idpf_send_alloc_vectors_msg - Send virtchnl alloc vectors message
2268 * @adapter: Driver specific private structure
2269 * @num_vectors: number of vectors to be allocated
2270 *
2271 * Returns 0 on success, negative on failure.
2272 */
2273int idpf_send_alloc_vectors_msg(struct idpf_adapter *adapter, u16 num_vectors)
2274{
2275 struct virtchnl2_alloc_vectors *alloc_vec, *rcvd_vec;
2276 struct virtchnl2_alloc_vectors ac = { };
2277 u16 num_vchunks;
2278 int size, err;
2279
2280 ac.num_vectors = cpu_to_le16(num_vectors);
2281
2282 mutex_lock(&adapter->vc_buf_lock);
2283
2284 err = idpf_send_mb_msg(adapter, VIRTCHNL2_OP_ALLOC_VECTORS,
2285 sizeof(ac), (u8 *)&ac);
2286 if (err)
2287 goto rel_lock;
2288
2289 err = idpf_wait_for_event(adapter, NULL, IDPF_VC_ALLOC_VECTORS,
2290 IDPF_VC_ALLOC_VECTORS_ERR);
2291 if (err)
2292 goto rel_lock;
2293
2294 rcvd_vec = (struct virtchnl2_alloc_vectors *)adapter->vc_msg;
2295 num_vchunks = le16_to_cpu(rcvd_vec->vchunks.num_vchunks);
2296
2297 size = struct_size(rcvd_vec, vchunks.vchunks, num_vchunks);
2298 if (size > sizeof(adapter->vc_msg)) {
2299 err = -EINVAL;
2300 goto rel_lock;
2301 }
2302
2303 kfree(adapter->req_vec_chunks);
2304 adapter->req_vec_chunks = NULL;
2305 adapter->req_vec_chunks = kmemdup(adapter->vc_msg, size, GFP_KERNEL);
2306 if (!adapter->req_vec_chunks) {
2307 err = -ENOMEM;
2308 goto rel_lock;
2309 }
2310
2311 alloc_vec = adapter->req_vec_chunks;
2312 if (le16_to_cpu(alloc_vec->num_vectors) < num_vectors) {
2313 kfree(adapter->req_vec_chunks);
2314 adapter->req_vec_chunks = NULL;
2315 err = -EINVAL;
2316 }
2317
2318rel_lock:
2319 mutex_unlock(&adapter->vc_buf_lock);
2320
2321 return err;
2322}
2323
2324/**
2325 * idpf_send_dealloc_vectors_msg - Send virtchnl de allocate vectors message
2326 * @adapter: Driver specific private structure
2327 *
2328 * Returns 0 on success, negative on failure.
2329 */
2330int idpf_send_dealloc_vectors_msg(struct idpf_adapter *adapter)
2331{
2332 struct virtchnl2_alloc_vectors *ac = adapter->req_vec_chunks;
2333 struct virtchnl2_vector_chunks *vcs = &ac->vchunks;
2334 int buf_size, err;
2335
2336 buf_size = struct_size(vcs, vchunks, le16_to_cpu(vcs->num_vchunks));
2337
2338 mutex_lock(&adapter->vc_buf_lock);
2339
2340 err = idpf_send_mb_msg(adapter, VIRTCHNL2_OP_DEALLOC_VECTORS, buf_size,
2341 (u8 *)vcs);
2342 if (err)
2343 goto rel_lock;
2344
2345 err = idpf_min_wait_for_event(adapter, NULL, IDPF_VC_DEALLOC_VECTORS,
2346 IDPF_VC_DEALLOC_VECTORS_ERR);
2347 if (err)
2348 goto rel_lock;
2349
2350 kfree(adapter->req_vec_chunks);
2351 adapter->req_vec_chunks = NULL;
2352
2353rel_lock:
2354 mutex_unlock(&adapter->vc_buf_lock);
2355
2356 return err;
2357}
2358
2359/**
2360 * idpf_get_max_vfs - Get max number of vfs supported
2361 * @adapter: Driver specific private structure
2362 *
2363 * Returns max number of VFs
2364 */
2365static int idpf_get_max_vfs(struct idpf_adapter *adapter)
2366{
2367 return le16_to_cpu(adapter->caps.max_sriov_vfs);
2368}
2369
2370/**
2371 * idpf_send_set_sriov_vfs_msg - Send virtchnl set sriov vfs message
2372 * @adapter: Driver specific private structure
2373 * @num_vfs: number of virtual functions to be created
2374 *
2375 * Returns 0 on success, negative on failure.
2376 */
2377int idpf_send_set_sriov_vfs_msg(struct idpf_adapter *adapter, u16 num_vfs)
2378{
2379 struct virtchnl2_sriov_vfs_info svi = { };
2380 int err;
2381
2382 svi.num_vfs = cpu_to_le16(num_vfs);
2383
2384 mutex_lock(&adapter->vc_buf_lock);
2385
2386 err = idpf_send_mb_msg(adapter, VIRTCHNL2_OP_SET_SRIOV_VFS,
2387 sizeof(svi), (u8 *)&svi);
2388 if (err)
2389 goto rel_lock;
2390
2391 err = idpf_wait_for_event(adapter, NULL, IDPF_VC_SET_SRIOV_VFS,
2392 IDPF_VC_SET_SRIOV_VFS_ERR);
2393
2394rel_lock:
2395 mutex_unlock(&adapter->vc_buf_lock);
2396
2397 return err;
2398}
2399
2400/**
2401 * idpf_send_get_stats_msg - Send virtchnl get statistics message
2402 * @vport: vport to get stats for
2403 *
2404 * Returns 0 on success, negative on failure.
2405 */
2406int idpf_send_get_stats_msg(struct idpf_vport *vport)
2407{
2408 struct idpf_netdev_priv *np = netdev_priv(vport->netdev);
2409 struct rtnl_link_stats64 *netstats = &np->netstats;
2410 struct idpf_adapter *adapter = vport->adapter;
2411 struct virtchnl2_vport_stats stats_msg = { };
2412 struct virtchnl2_vport_stats *stats;
2413 int err;
2414
2415 /* Don't send get_stats message if the link is down */
2416 if (np->state <= __IDPF_VPORT_DOWN)
2417 return 0;
2418
2419 stats_msg.vport_id = cpu_to_le32(vport->vport_id);
2420
2421 mutex_lock(&vport->vc_buf_lock);
2422
2423 err = idpf_send_mb_msg(adapter, VIRTCHNL2_OP_GET_STATS,
2424 sizeof(struct virtchnl2_vport_stats),
2425 (u8 *)&stats_msg);
2426 if (err)
2427 goto rel_lock;
2428
2429 err = idpf_wait_for_event(adapter, vport, IDPF_VC_GET_STATS,
2430 IDPF_VC_GET_STATS_ERR);
2431 if (err)
2432 goto rel_lock;
2433
2434 stats = (struct virtchnl2_vport_stats *)vport->vc_msg;
2435
2436 spin_lock_bh(&np->stats_lock);
2437
2438 netstats->rx_packets = le64_to_cpu(stats->rx_unicast) +
2439 le64_to_cpu(stats->rx_multicast) +
2440 le64_to_cpu(stats->rx_broadcast);
2441 netstats->rx_bytes = le64_to_cpu(stats->rx_bytes);
2442 netstats->rx_dropped = le64_to_cpu(stats->rx_discards);
2443 netstats->rx_over_errors = le64_to_cpu(stats->rx_overflow_drop);
2444 netstats->rx_length_errors = le64_to_cpu(stats->rx_invalid_frame_length);
2445
2446 netstats->tx_packets = le64_to_cpu(stats->tx_unicast) +
2447 le64_to_cpu(stats->tx_multicast) +
2448 le64_to_cpu(stats->tx_broadcast);
2449 netstats->tx_bytes = le64_to_cpu(stats->tx_bytes);
2450 netstats->tx_errors = le64_to_cpu(stats->tx_errors);
2451 netstats->tx_dropped = le64_to_cpu(stats->tx_discards);
2452
2453 vport->port_stats.vport_stats = *stats;
2454
2455 spin_unlock_bh(&np->stats_lock);
2456
2457rel_lock:
2458 mutex_unlock(&vport->vc_buf_lock);
2459
2460 return err;
2461}
2462
2463/**
2464 * idpf_send_get_set_rss_lut_msg - Send virtchnl get or set rss lut message
2465 * @vport: virtual port data structure
2466 * @get: flag to set or get rss look up table
2467 *
2468 * Returns 0 on success, negative on failure.
2469 */
2470int idpf_send_get_set_rss_lut_msg(struct idpf_vport *vport, bool get)
2471{
2472 struct idpf_adapter *adapter = vport->adapter;
2473 struct virtchnl2_rss_lut *recv_rl;
2474 struct idpf_rss_data *rss_data;
2475 struct virtchnl2_rss_lut *rl;
2476 int buf_size, lut_buf_size;
2477 int i, err;
2478
2479 rss_data = &adapter->vport_config[vport->idx]->user_config.rss_data;
2480 buf_size = struct_size(rl, lut, rss_data->rss_lut_size);
2481 rl = kzalloc(buf_size, GFP_KERNEL);
2482 if (!rl)
2483 return -ENOMEM;
2484
2485 rl->vport_id = cpu_to_le32(vport->vport_id);
2486 mutex_lock(&vport->vc_buf_lock);
2487
2488 if (!get) {
2489 rl->lut_entries = cpu_to_le16(rss_data->rss_lut_size);
2490 for (i = 0; i < rss_data->rss_lut_size; i++)
2491 rl->lut[i] = cpu_to_le32(rss_data->rss_lut[i]);
2492
2493 err = idpf_send_mb_msg(adapter, VIRTCHNL2_OP_SET_RSS_LUT,
2494 buf_size, (u8 *)rl);
2495 if (err)
2496 goto free_mem;
2497
2498 err = idpf_wait_for_event(adapter, vport, IDPF_VC_SET_RSS_LUT,
2499 IDPF_VC_SET_RSS_LUT_ERR);
2500
2501 goto free_mem;
2502 }
2503
2504 err = idpf_send_mb_msg(adapter, VIRTCHNL2_OP_GET_RSS_LUT,
2505 buf_size, (u8 *)rl);
2506 if (err)
2507 goto free_mem;
2508
2509 err = idpf_wait_for_event(adapter, vport, IDPF_VC_GET_RSS_LUT,
2510 IDPF_VC_GET_RSS_LUT_ERR);
2511 if (err)
2512 goto free_mem;
2513
2514 recv_rl = (struct virtchnl2_rss_lut *)vport->vc_msg;
2515 if (rss_data->rss_lut_size == le16_to_cpu(recv_rl->lut_entries))
2516 goto do_memcpy;
2517
2518 rss_data->rss_lut_size = le16_to_cpu(recv_rl->lut_entries);
2519 kfree(rss_data->rss_lut);
2520
2521 lut_buf_size = rss_data->rss_lut_size * sizeof(u32);
2522 rss_data->rss_lut = kzalloc(lut_buf_size, GFP_KERNEL);
2523 if (!rss_data->rss_lut) {
2524 rss_data->rss_lut_size = 0;
2525 err = -ENOMEM;
2526 goto free_mem;
2527 }
2528
2529do_memcpy:
2530 memcpy(rss_data->rss_lut, vport->vc_msg, rss_data->rss_lut_size);
2531free_mem:
2532 mutex_unlock(&vport->vc_buf_lock);
2533 kfree(rl);
2534
2535 return err;
2536}
2537
2538/**
2539 * idpf_send_get_set_rss_key_msg - Send virtchnl get or set rss key message
2540 * @vport: virtual port data structure
2541 * @get: flag to set or get rss look up table
2542 *
2543 * Returns 0 on success, negative on failure
2544 */
2545int idpf_send_get_set_rss_key_msg(struct idpf_vport *vport, bool get)
2546{
2547 struct idpf_adapter *adapter = vport->adapter;
2548 struct virtchnl2_rss_key *recv_rk;
2549 struct idpf_rss_data *rss_data;
2550 struct virtchnl2_rss_key *rk;
2551 int i, buf_size, err;
2552
2553 rss_data = &adapter->vport_config[vport->idx]->user_config.rss_data;
2554 buf_size = struct_size(rk, key_flex, rss_data->rss_key_size);
2555 rk = kzalloc(buf_size, GFP_KERNEL);
2556 if (!rk)
2557 return -ENOMEM;
2558
2559 rk->vport_id = cpu_to_le32(vport->vport_id);
2560 mutex_lock(&vport->vc_buf_lock);
2561
2562 if (get) {
2563 err = idpf_send_mb_msg(adapter, VIRTCHNL2_OP_GET_RSS_KEY,
2564 buf_size, (u8 *)rk);
2565 if (err)
2566 goto error;
2567
2568 err = idpf_wait_for_event(adapter, vport, IDPF_VC_GET_RSS_KEY,
2569 IDPF_VC_GET_RSS_KEY_ERR);
2570 if (err)
2571 goto error;
2572
2573 recv_rk = (struct virtchnl2_rss_key *)vport->vc_msg;
2574 if (rss_data->rss_key_size !=
2575 le16_to_cpu(recv_rk->key_len)) {
2576 rss_data->rss_key_size =
2577 min_t(u16, NETDEV_RSS_KEY_LEN,
2578 le16_to_cpu(recv_rk->key_len));
2579 kfree(rss_data->rss_key);
2580 rss_data->rss_key = kzalloc(rss_data->rss_key_size,
2581 GFP_KERNEL);
2582 if (!rss_data->rss_key) {
2583 rss_data->rss_key_size = 0;
2584 err = -ENOMEM;
2585 goto error;
2586 }
2587 }
2588 memcpy(rss_data->rss_key, recv_rk->key_flex,
2589 rss_data->rss_key_size);
2590 } else {
2591 rk->key_len = cpu_to_le16(rss_data->rss_key_size);
2592 for (i = 0; i < rss_data->rss_key_size; i++)
2593 rk->key_flex[i] = rss_data->rss_key[i];
2594
2595 err = idpf_send_mb_msg(adapter, VIRTCHNL2_OP_SET_RSS_KEY,
2596 buf_size, (u8 *)rk);
2597 if (err)
2598 goto error;
2599
2600 err = idpf_wait_for_event(adapter, vport, IDPF_VC_SET_RSS_KEY,
2601 IDPF_VC_SET_RSS_KEY_ERR);
2602 }
2603
2604error:
2605 mutex_unlock(&vport->vc_buf_lock);
2606 kfree(rk);
2607
2608 return err;
2609}
2610
2611/**
2612 * idpf_fill_ptype_lookup - Fill L3 specific fields in ptype lookup table
2613 * @ptype: ptype lookup table
2614 * @pstate: state machine for ptype lookup table
2615 * @ipv4: ipv4 or ipv6
2616 * @frag: fragmentation allowed
2617 *
2618 */
2619static void idpf_fill_ptype_lookup(struct idpf_rx_ptype_decoded *ptype,
2620 struct idpf_ptype_state *pstate,
2621 bool ipv4, bool frag)
2622{
2623 if (!pstate->outer_ip || !pstate->outer_frag) {
2624 ptype->outer_ip = IDPF_RX_PTYPE_OUTER_IP;
2625 pstate->outer_ip = true;
2626
2627 if (ipv4)
2628 ptype->outer_ip_ver = IDPF_RX_PTYPE_OUTER_IPV4;
2629 else
2630 ptype->outer_ip_ver = IDPF_RX_PTYPE_OUTER_IPV6;
2631
2632 if (frag) {
2633 ptype->outer_frag = IDPF_RX_PTYPE_FRAG;
2634 pstate->outer_frag = true;
2635 }
2636 } else {
2637 ptype->tunnel_type = IDPF_RX_PTYPE_TUNNEL_IP_IP;
2638 pstate->tunnel_state = IDPF_PTYPE_TUNNEL_IP;
2639
2640 if (ipv4)
2641 ptype->tunnel_end_prot =
2642 IDPF_RX_PTYPE_TUNNEL_END_IPV4;
2643 else
2644 ptype->tunnel_end_prot =
2645 IDPF_RX_PTYPE_TUNNEL_END_IPV6;
2646
2647 if (frag)
2648 ptype->tunnel_end_frag = IDPF_RX_PTYPE_FRAG;
2649 }
2650}
2651
2652/**
2653 * idpf_send_get_rx_ptype_msg - Send virtchnl for ptype info
2654 * @vport: virtual port data structure
2655 *
2656 * Returns 0 on success, negative on failure.
2657 */
2658int idpf_send_get_rx_ptype_msg(struct idpf_vport *vport)
2659{
2660 struct idpf_rx_ptype_decoded *ptype_lkup = vport->rx_ptype_lkup;
2661 struct virtchnl2_get_ptype_info get_ptype_info;
2662 int max_ptype, ptypes_recvd = 0, ptype_offset;
2663 struct idpf_adapter *adapter = vport->adapter;
2664 struct virtchnl2_get_ptype_info *ptype_info;
2665 u16 next_ptype_id = 0;
2666 int err = 0, i, j, k;
2667
2668 if (idpf_is_queue_model_split(vport->rxq_model))
2669 max_ptype = IDPF_RX_MAX_PTYPE;
2670 else
2671 max_ptype = IDPF_RX_MAX_BASE_PTYPE;
2672
2673 memset(vport->rx_ptype_lkup, 0, sizeof(vport->rx_ptype_lkup));
2674
2675 ptype_info = kzalloc(IDPF_CTLQ_MAX_BUF_LEN, GFP_KERNEL);
2676 if (!ptype_info)
2677 return -ENOMEM;
2678
2679 mutex_lock(&adapter->vc_buf_lock);
2680
2681 while (next_ptype_id < max_ptype) {
2682 get_ptype_info.start_ptype_id = cpu_to_le16(next_ptype_id);
2683
2684 if ((next_ptype_id + IDPF_RX_MAX_PTYPES_PER_BUF) > max_ptype)
2685 get_ptype_info.num_ptypes =
2686 cpu_to_le16(max_ptype - next_ptype_id);
2687 else
2688 get_ptype_info.num_ptypes =
2689 cpu_to_le16(IDPF_RX_MAX_PTYPES_PER_BUF);
2690
2691 err = idpf_send_mb_msg(adapter, VIRTCHNL2_OP_GET_PTYPE_INFO,
2692 sizeof(struct virtchnl2_get_ptype_info),
2693 (u8 *)&get_ptype_info);
2694 if (err)
2695 goto vc_buf_unlock;
2696
2697 err = idpf_wait_for_event(adapter, NULL, IDPF_VC_GET_PTYPE_INFO,
2698 IDPF_VC_GET_PTYPE_INFO_ERR);
2699 if (err)
2700 goto vc_buf_unlock;
2701
2702 memcpy(ptype_info, adapter->vc_msg, IDPF_CTLQ_MAX_BUF_LEN);
2703
2704 ptypes_recvd += le16_to_cpu(ptype_info->num_ptypes);
2705 if (ptypes_recvd > max_ptype) {
2706 err = -EINVAL;
2707 goto vc_buf_unlock;
2708 }
2709
2710 next_ptype_id = le16_to_cpu(get_ptype_info.start_ptype_id) +
2711 le16_to_cpu(get_ptype_info.num_ptypes);
2712
2713 ptype_offset = IDPF_RX_PTYPE_HDR_SZ;
2714
2715 for (i = 0; i < le16_to_cpu(ptype_info->num_ptypes); i++) {
2716 struct idpf_ptype_state pstate = { };
2717 struct virtchnl2_ptype *ptype;
2718 u16 id;
2719
2720 ptype = (struct virtchnl2_ptype *)
2721 ((u8 *)ptype_info + ptype_offset);
2722
2723 ptype_offset += IDPF_GET_PTYPE_SIZE(ptype);
2724 if (ptype_offset > IDPF_CTLQ_MAX_BUF_LEN) {
2725 err = -EINVAL;
2726 goto vc_buf_unlock;
2727 }
2728
2729 /* 0xFFFF indicates end of ptypes */
2730 if (le16_to_cpu(ptype->ptype_id_10) ==
2731 IDPF_INVALID_PTYPE_ID) {
2732 err = 0;
2733 goto vc_buf_unlock;
2734 }
2735
2736 if (idpf_is_queue_model_split(vport->rxq_model))
2737 k = le16_to_cpu(ptype->ptype_id_10);
2738 else
2739 k = ptype->ptype_id_8;
2740
2741 if (ptype->proto_id_count)
2742 ptype_lkup[k].known = 1;
2743
2744 for (j = 0; j < ptype->proto_id_count; j++) {
2745 id = le16_to_cpu(ptype->proto_id[j]);
2746 switch (id) {
2747 case VIRTCHNL2_PROTO_HDR_GRE:
2748 if (pstate.tunnel_state ==
2749 IDPF_PTYPE_TUNNEL_IP) {
2750 ptype_lkup[k].tunnel_type =
2751 IDPF_RX_PTYPE_TUNNEL_IP_GRENAT;
2752 pstate.tunnel_state |=
2753 IDPF_PTYPE_TUNNEL_IP_GRENAT;
2754 }
2755 break;
2756 case VIRTCHNL2_PROTO_HDR_MAC:
2757 ptype_lkup[k].outer_ip =
2758 IDPF_RX_PTYPE_OUTER_L2;
2759 if (pstate.tunnel_state ==
2760 IDPF_TUN_IP_GRE) {
2761 ptype_lkup[k].tunnel_type =
2762 IDPF_RX_PTYPE_TUNNEL_IP_GRENAT_MAC;
2763 pstate.tunnel_state |=
2764 IDPF_PTYPE_TUNNEL_IP_GRENAT_MAC;
2765 }
2766 break;
2767 case VIRTCHNL2_PROTO_HDR_IPV4:
2768 idpf_fill_ptype_lookup(&ptype_lkup[k],
2769 &pstate, true,
2770 false);
2771 break;
2772 case VIRTCHNL2_PROTO_HDR_IPV6:
2773 idpf_fill_ptype_lookup(&ptype_lkup[k],
2774 &pstate, false,
2775 false);
2776 break;
2777 case VIRTCHNL2_PROTO_HDR_IPV4_FRAG:
2778 idpf_fill_ptype_lookup(&ptype_lkup[k],
2779 &pstate, true,
2780 true);
2781 break;
2782 case VIRTCHNL2_PROTO_HDR_IPV6_FRAG:
2783 idpf_fill_ptype_lookup(&ptype_lkup[k],
2784 &pstate, false,
2785 true);
2786 break;
2787 case VIRTCHNL2_PROTO_HDR_UDP:
2788 ptype_lkup[k].inner_prot =
2789 IDPF_RX_PTYPE_INNER_PROT_UDP;
2790 break;
2791 case VIRTCHNL2_PROTO_HDR_TCP:
2792 ptype_lkup[k].inner_prot =
2793 IDPF_RX_PTYPE_INNER_PROT_TCP;
2794 break;
2795 case VIRTCHNL2_PROTO_HDR_SCTP:
2796 ptype_lkup[k].inner_prot =
2797 IDPF_RX_PTYPE_INNER_PROT_SCTP;
2798 break;
2799 case VIRTCHNL2_PROTO_HDR_ICMP:
2800 ptype_lkup[k].inner_prot =
2801 IDPF_RX_PTYPE_INNER_PROT_ICMP;
2802 break;
2803 case VIRTCHNL2_PROTO_HDR_PAY:
2804 ptype_lkup[k].payload_layer =
2805 IDPF_RX_PTYPE_PAYLOAD_LAYER_PAY2;
2806 break;
2807 case VIRTCHNL2_PROTO_HDR_ICMPV6:
2808 case VIRTCHNL2_PROTO_HDR_IPV6_EH:
2809 case VIRTCHNL2_PROTO_HDR_PRE_MAC:
2810 case VIRTCHNL2_PROTO_HDR_POST_MAC:
2811 case VIRTCHNL2_PROTO_HDR_ETHERTYPE:
2812 case VIRTCHNL2_PROTO_HDR_SVLAN:
2813 case VIRTCHNL2_PROTO_HDR_CVLAN:
2814 case VIRTCHNL2_PROTO_HDR_MPLS:
2815 case VIRTCHNL2_PROTO_HDR_MMPLS:
2816 case VIRTCHNL2_PROTO_HDR_PTP:
2817 case VIRTCHNL2_PROTO_HDR_CTRL:
2818 case VIRTCHNL2_PROTO_HDR_LLDP:
2819 case VIRTCHNL2_PROTO_HDR_ARP:
2820 case VIRTCHNL2_PROTO_HDR_ECP:
2821 case VIRTCHNL2_PROTO_HDR_EAPOL:
2822 case VIRTCHNL2_PROTO_HDR_PPPOD:
2823 case VIRTCHNL2_PROTO_HDR_PPPOE:
2824 case VIRTCHNL2_PROTO_HDR_IGMP:
2825 case VIRTCHNL2_PROTO_HDR_AH:
2826 case VIRTCHNL2_PROTO_HDR_ESP:
2827 case VIRTCHNL2_PROTO_HDR_IKE:
2828 case VIRTCHNL2_PROTO_HDR_NATT_KEEP:
2829 case VIRTCHNL2_PROTO_HDR_L2TPV2:
2830 case VIRTCHNL2_PROTO_HDR_L2TPV2_CONTROL:
2831 case VIRTCHNL2_PROTO_HDR_L2TPV3:
2832 case VIRTCHNL2_PROTO_HDR_GTP:
2833 case VIRTCHNL2_PROTO_HDR_GTP_EH:
2834 case VIRTCHNL2_PROTO_HDR_GTPCV2:
2835 case VIRTCHNL2_PROTO_HDR_GTPC_TEID:
2836 case VIRTCHNL2_PROTO_HDR_GTPU:
2837 case VIRTCHNL2_PROTO_HDR_GTPU_UL:
2838 case VIRTCHNL2_PROTO_HDR_GTPU_DL:
2839 case VIRTCHNL2_PROTO_HDR_ECPRI:
2840 case VIRTCHNL2_PROTO_HDR_VRRP:
2841 case VIRTCHNL2_PROTO_HDR_OSPF:
2842 case VIRTCHNL2_PROTO_HDR_TUN:
2843 case VIRTCHNL2_PROTO_HDR_NVGRE:
2844 case VIRTCHNL2_PROTO_HDR_VXLAN:
2845 case VIRTCHNL2_PROTO_HDR_VXLAN_GPE:
2846 case VIRTCHNL2_PROTO_HDR_GENEVE:
2847 case VIRTCHNL2_PROTO_HDR_NSH:
2848 case VIRTCHNL2_PROTO_HDR_QUIC:
2849 case VIRTCHNL2_PROTO_HDR_PFCP:
2850 case VIRTCHNL2_PROTO_HDR_PFCP_NODE:
2851 case VIRTCHNL2_PROTO_HDR_PFCP_SESSION:
2852 case VIRTCHNL2_PROTO_HDR_RTP:
2853 case VIRTCHNL2_PROTO_HDR_NO_PROTO:
2854 break;
2855 default:
2856 break;
2857 }
2858 }
2859 }
2860 }
2861
2862vc_buf_unlock:
2863 mutex_unlock(&adapter->vc_buf_lock);
2864 kfree(ptype_info);
2865
2866 return err;
2867}
2868
2869/**
2870 * idpf_send_ena_dis_loopback_msg - Send virtchnl enable/disable loopback
2871 * message
2872 * @vport: virtual port data structure
2873 *
2874 * Returns 0 on success, negative on failure.
2875 */
2876int idpf_send_ena_dis_loopback_msg(struct idpf_vport *vport)
2877{
2878 struct virtchnl2_loopback loopback;
2879 int err;
2880
2881 loopback.vport_id = cpu_to_le32(vport->vport_id);
2882 loopback.enable = idpf_is_feature_ena(vport, NETIF_F_LOOPBACK);
2883
2884 mutex_lock(&vport->vc_buf_lock);
2885
2886 err = idpf_send_mb_msg(vport->adapter, VIRTCHNL2_OP_LOOPBACK,
2887 sizeof(loopback), (u8 *)&loopback);
2888 if (err)
2889 goto rel_lock;
2890
2891 err = idpf_wait_for_event(vport->adapter, vport,
2892 IDPF_VC_LOOPBACK_STATE,
2893 IDPF_VC_LOOPBACK_STATE_ERR);
2894
2895rel_lock:
2896 mutex_unlock(&vport->vc_buf_lock);
2897
2898 return err;
2899}
2900
2901/**
2902 * idpf_find_ctlq - Given a type and id, find ctlq info
2903 * @hw: hardware struct
2904 * @type: type of ctrlq to find
2905 * @id: ctlq id to find
2906 *
2907 * Returns pointer to found ctlq info struct, NULL otherwise.
2908 */
2909static struct idpf_ctlq_info *idpf_find_ctlq(struct idpf_hw *hw,
2910 enum idpf_ctlq_type type, int id)
2911{
2912 struct idpf_ctlq_info *cq, *tmp;
2913
2914 list_for_each_entry_safe(cq, tmp, &hw->cq_list_head, cq_list)
2915 if (cq->q_id == id && cq->cq_type == type)
2916 return cq;
2917
2918 return NULL;
2919}
2920
2921/**
2922 * idpf_init_dflt_mbx - Setup default mailbox parameters and make request
2923 * @adapter: adapter info struct
2924 *
2925 * Returns 0 on success, negative otherwise
2926 */
2927int idpf_init_dflt_mbx(struct idpf_adapter *adapter)
2928{
2929 struct idpf_ctlq_create_info ctlq_info[] = {
2930 {
2931 .type = IDPF_CTLQ_TYPE_MAILBOX_TX,
2932 .id = IDPF_DFLT_MBX_ID,
2933 .len = IDPF_DFLT_MBX_Q_LEN,
2934 .buf_size = IDPF_CTLQ_MAX_BUF_LEN
2935 },
2936 {
2937 .type = IDPF_CTLQ_TYPE_MAILBOX_RX,
2938 .id = IDPF_DFLT_MBX_ID,
2939 .len = IDPF_DFLT_MBX_Q_LEN,
2940 .buf_size = IDPF_CTLQ_MAX_BUF_LEN
2941 }
2942 };
2943 struct idpf_hw *hw = &adapter->hw;
2944 int err;
2945
2946 adapter->dev_ops.reg_ops.ctlq_reg_init(ctlq_info);
2947
2948 err = idpf_ctlq_init(hw, IDPF_NUM_DFLT_MBX_Q, ctlq_info);
2949 if (err)
2950 return err;
2951
2952 hw->asq = idpf_find_ctlq(hw, IDPF_CTLQ_TYPE_MAILBOX_TX,
2953 IDPF_DFLT_MBX_ID);
2954 hw->arq = idpf_find_ctlq(hw, IDPF_CTLQ_TYPE_MAILBOX_RX,
2955 IDPF_DFLT_MBX_ID);
2956
2957 if (!hw->asq || !hw->arq) {
2958 idpf_ctlq_deinit(hw);
2959
2960 return -ENOENT;
2961 }
2962
2963 adapter->state = __IDPF_STARTUP;
2964
2965 return 0;
2966}
2967
2968/**
2969 * idpf_deinit_dflt_mbx - Free up ctlqs setup
2970 * @adapter: Driver specific private data structure
2971 */
2972void idpf_deinit_dflt_mbx(struct idpf_adapter *adapter)
2973{
2974 if (adapter->hw.arq && adapter->hw.asq) {
2975 idpf_mb_clean(adapter);
2976 idpf_ctlq_deinit(&adapter->hw);
2977 }
2978 adapter->hw.arq = NULL;
2979 adapter->hw.asq = NULL;
2980}
2981
2982/**
2983 * idpf_vport_params_buf_rel - Release memory for MailBox resources
2984 * @adapter: Driver specific private data structure
2985 *
2986 * Will release memory to hold the vport parameters received on MailBox
2987 */
2988static void idpf_vport_params_buf_rel(struct idpf_adapter *adapter)
2989{
2990 kfree(adapter->vport_params_recvd);
2991 adapter->vport_params_recvd = NULL;
2992 kfree(adapter->vport_params_reqd);
2993 adapter->vport_params_reqd = NULL;
2994 kfree(adapter->vport_ids);
2995 adapter->vport_ids = NULL;
2996}
2997
2998/**
2999 * idpf_vport_params_buf_alloc - Allocate memory for MailBox resources
3000 * @adapter: Driver specific private data structure
3001 *
3002 * Will alloc memory to hold the vport parameters received on MailBox
3003 */
3004static int idpf_vport_params_buf_alloc(struct idpf_adapter *adapter)
3005{
3006 u16 num_max_vports = idpf_get_max_vports(adapter);
3007
3008 adapter->vport_params_reqd = kcalloc(num_max_vports,
3009 sizeof(*adapter->vport_params_reqd),
3010 GFP_KERNEL);
3011 if (!adapter->vport_params_reqd)
3012 return -ENOMEM;
3013
3014 adapter->vport_params_recvd = kcalloc(num_max_vports,
3015 sizeof(*adapter->vport_params_recvd),
3016 GFP_KERNEL);
3017 if (!adapter->vport_params_recvd)
3018 goto err_mem;
3019
3020 adapter->vport_ids = kcalloc(num_max_vports, sizeof(u32), GFP_KERNEL);
3021 if (!adapter->vport_ids)
3022 goto err_mem;
3023
3024 if (adapter->vport_config)
3025 return 0;
3026
3027 adapter->vport_config = kcalloc(num_max_vports,
3028 sizeof(*adapter->vport_config),
3029 GFP_KERNEL);
3030 if (!adapter->vport_config)
3031 goto err_mem;
3032
3033 return 0;
3034
3035err_mem:
3036 idpf_vport_params_buf_rel(adapter);
3037
3038 return -ENOMEM;
3039}
3040
3041/**
3042 * idpf_vc_core_init - Initialize state machine and get driver specific
3043 * resources
3044 * @adapter: Driver specific private structure
3045 *
3046 * This function will initialize the state machine and request all necessary
3047 * resources required by the device driver. Once the state machine is
3048 * initialized, allocate memory to store vport specific information and also
3049 * requests required interrupts.
3050 *
3051 * Returns 0 on success, -EAGAIN function will get called again,
3052 * otherwise negative on failure.
3053 */
3054int idpf_vc_core_init(struct idpf_adapter *adapter)
3055{
3056 int task_delay = 30;
3057 u16 num_max_vports;
3058 int err = 0;
3059
3060 while (adapter->state != __IDPF_INIT_SW) {
3061 switch (adapter->state) {
3062 case __IDPF_STARTUP:
3063 if (idpf_send_ver_msg(adapter))
3064 goto init_failed;
3065 adapter->state = __IDPF_VER_CHECK;
3066 goto restart;
3067 case __IDPF_VER_CHECK:
3068 err = idpf_recv_ver_msg(adapter);
3069 if (err == -EIO) {
3070 return err;
3071 } else if (err == -EAGAIN) {
3072 adapter->state = __IDPF_STARTUP;
3073 goto restart;
3074 } else if (err) {
3075 goto init_failed;
3076 }
3077 if (idpf_send_get_caps_msg(adapter))
3078 goto init_failed;
3079 adapter->state = __IDPF_GET_CAPS;
3080 goto restart;
3081 case __IDPF_GET_CAPS:
3082 if (idpf_recv_get_caps_msg(adapter))
3083 goto init_failed;
3084 adapter->state = __IDPF_INIT_SW;
3085 break;
3086 default:
3087 dev_err(&adapter->pdev->dev, "Device is in bad state: %d\n",
3088 adapter->state);
3089 goto init_failed;
3090 }
3091 break;
3092restart:
3093 /* Give enough time before proceeding further with
3094 * state machine
3095 */
3096 msleep(task_delay);
3097 }
3098
3099 pci_sriov_set_totalvfs(adapter->pdev, idpf_get_max_vfs(adapter));
3100 num_max_vports = idpf_get_max_vports(adapter);
3101 adapter->max_vports = num_max_vports;
3102 adapter->vports = kcalloc(num_max_vports, sizeof(*adapter->vports),
3103 GFP_KERNEL);
3104 if (!adapter->vports)
3105 return -ENOMEM;
3106
3107 if (!adapter->netdevs) {
3108 adapter->netdevs = kcalloc(num_max_vports,
3109 sizeof(struct net_device *),
3110 GFP_KERNEL);
3111 if (!adapter->netdevs) {
3112 err = -ENOMEM;
3113 goto err_netdev_alloc;
3114 }
3115 }
3116
3117 err = idpf_vport_params_buf_alloc(adapter);
3118 if (err) {
3119 dev_err(&adapter->pdev->dev, "Failed to alloc vport params buffer: %d\n",
3120 err);
3121 goto err_netdev_alloc;
3122 }
3123
3124 /* Start the mailbox task before requesting vectors. This will ensure
3125 * vector information response from mailbox is handled
3126 */
3127 queue_delayed_work(adapter->mbx_wq, &adapter->mbx_task, 0);
3128
3129 queue_delayed_work(adapter->serv_wq, &adapter->serv_task,
3130 msecs_to_jiffies(5 * (adapter->pdev->devfn & 0x07)));
3131
3132 err = idpf_intr_req(adapter);
3133 if (err) {
3134 dev_err(&adapter->pdev->dev, "failed to enable interrupt vectors: %d\n",
3135 err);
3136 goto err_intr_req;
3137 }
3138
3139 idpf_init_avail_queues(adapter);
3140
3141 /* Skew the delay for init tasks for each function based on fn number
3142 * to prevent every function from making the same call simultaneously.
3143 */
3144 queue_delayed_work(adapter->init_wq, &adapter->init_task,
3145 msecs_to_jiffies(5 * (adapter->pdev->devfn & 0x07)));
3146
3147 goto no_err;
3148
3149err_intr_req:
3150 cancel_delayed_work_sync(&adapter->serv_task);
3151 cancel_delayed_work_sync(&adapter->mbx_task);
3152 idpf_vport_params_buf_rel(adapter);
3153err_netdev_alloc:
3154 kfree(adapter->vports);
3155 adapter->vports = NULL;
3156no_err:
3157 return err;
3158
3159init_failed:
3160 /* Don't retry if we're trying to go down, just bail. */
3161 if (test_bit(IDPF_REMOVE_IN_PROG, adapter->flags))
3162 return err;
3163
3164 if (++adapter->mb_wait_count > IDPF_MB_MAX_ERR) {
3165 dev_err(&adapter->pdev->dev, "Failed to establish mailbox communications with hardware\n");
3166
3167 return -EFAULT;
3168 }
3169 /* If it reached here, it is possible that mailbox queue initialization
3170 * register writes might not have taken effect. Retry to initialize
3171 * the mailbox again
3172 */
3173 adapter->state = __IDPF_STARTUP;
3174 idpf_deinit_dflt_mbx(adapter);
3175 set_bit(IDPF_HR_DRV_LOAD, adapter->flags);
3176 queue_delayed_work(adapter->vc_event_wq, &adapter->vc_event_task,
3177 msecs_to_jiffies(task_delay));
3178
3179 return -EAGAIN;
3180}
3181
3182/**
3183 * idpf_vc_core_deinit - Device deinit routine
3184 * @adapter: Driver specific private structure
3185 *
3186 */
3187void idpf_vc_core_deinit(struct idpf_adapter *adapter)
3188{
3189 int i;
3190
3191 idpf_deinit_task(adapter);
3192 idpf_intr_rel(adapter);
3193 /* Set all bits as we dont know on which vc_state the vhnl_wq is
3194 * waiting on and wakeup the virtchnl workqueue even if it is waiting
3195 * for the response as we are going down
3196 */
3197 for (i = 0; i < IDPF_VC_NBITS; i++)
3198 set_bit(i, adapter->vc_state);
3199 wake_up(&adapter->vchnl_wq);
3200
3201 cancel_delayed_work_sync(&adapter->serv_task);
3202 cancel_delayed_work_sync(&adapter->mbx_task);
3203
3204 idpf_vport_params_buf_rel(adapter);
3205
3206 /* Clear all the bits */
3207 for (i = 0; i < IDPF_VC_NBITS; i++)
3208 clear_bit(i, adapter->vc_state);
3209
3210 kfree(adapter->vports);
3211 adapter->vports = NULL;
3212}
3213
3214/**
3215 * idpf_vport_alloc_vec_indexes - Get relative vector indexes
3216 * @vport: virtual port data struct
3217 *
3218 * This function requests the vector information required for the vport and
3219 * stores the vector indexes received from the 'global vector distribution'
3220 * in the vport's queue vectors array.
3221 *
3222 * Return 0 on success, error on failure
3223 */
3224int idpf_vport_alloc_vec_indexes(struct idpf_vport *vport)
3225{
3226 struct idpf_vector_info vec_info;
3227 int num_alloc_vecs;
3228
3229 vec_info.num_curr_vecs = vport->num_q_vectors;
3230 vec_info.num_req_vecs = max(vport->num_txq, vport->num_rxq);
3231 vec_info.default_vport = vport->default_vport;
3232 vec_info.index = vport->idx;
3233
3234 num_alloc_vecs = idpf_req_rel_vector_indexes(vport->adapter,
3235 vport->q_vector_idxs,
3236 &vec_info);
3237 if (num_alloc_vecs <= 0) {
3238 dev_err(&vport->adapter->pdev->dev, "Vector distribution failed: %d\n",
3239 num_alloc_vecs);
3240 return -EINVAL;
3241 }
3242
3243 vport->num_q_vectors = num_alloc_vecs;
3244
3245 return 0;
3246}
3247
3248/**
3249 * idpf_vport_init - Initialize virtual port
3250 * @vport: virtual port to be initialized
3251 * @max_q: vport max queue info
3252 *
3253 * Will initialize vport with the info received through MB earlier
3254 */
3255void idpf_vport_init(struct idpf_vport *vport, struct idpf_vport_max_q *max_q)
3256{
3257 struct idpf_adapter *adapter = vport->adapter;
3258 struct virtchnl2_create_vport *vport_msg;
3259 struct idpf_vport_config *vport_config;
3260 u16 tx_itr[] = {2, 8, 64, 128, 256};
3261 u16 rx_itr[] = {2, 8, 32, 96, 128};
3262 struct idpf_rss_data *rss_data;
3263 u16 idx = vport->idx;
3264
3265 vport_config = adapter->vport_config[idx];
3266 rss_data = &vport_config->user_config.rss_data;
3267 vport_msg = adapter->vport_params_recvd[idx];
3268
3269 vport_config->max_q.max_txq = max_q->max_txq;
3270 vport_config->max_q.max_rxq = max_q->max_rxq;
3271 vport_config->max_q.max_complq = max_q->max_complq;
3272 vport_config->max_q.max_bufq = max_q->max_bufq;
3273
3274 vport->txq_model = le16_to_cpu(vport_msg->txq_model);
3275 vport->rxq_model = le16_to_cpu(vport_msg->rxq_model);
3276 vport->vport_type = le16_to_cpu(vport_msg->vport_type);
3277 vport->vport_id = le32_to_cpu(vport_msg->vport_id);
3278
3279 rss_data->rss_key_size = min_t(u16, NETDEV_RSS_KEY_LEN,
3280 le16_to_cpu(vport_msg->rss_key_size));
3281 rss_data->rss_lut_size = le16_to_cpu(vport_msg->rss_lut_size);
3282
3283 ether_addr_copy(vport->default_mac_addr, vport_msg->default_mac_addr);
3284 vport->max_mtu = le16_to_cpu(vport_msg->max_mtu) - IDPF_PACKET_HDR_PAD;
3285
3286 /* Initialize Tx and Rx profiles for Dynamic Interrupt Moderation */
3287 memcpy(vport->rx_itr_profile, rx_itr, IDPF_DIM_PROFILE_SLOTS);
3288 memcpy(vport->tx_itr_profile, tx_itr, IDPF_DIM_PROFILE_SLOTS);
3289
3290 idpf_vport_set_hsplit(vport, ETHTOOL_TCP_DATA_SPLIT_ENABLED);
3291
3292 idpf_vport_init_num_qs(vport, vport_msg);
3293 idpf_vport_calc_num_q_desc(vport);
3294 idpf_vport_calc_num_q_groups(vport);
3295 idpf_vport_alloc_vec_indexes(vport);
3296
3297 vport->crc_enable = adapter->crc_enable;
3298}
3299
3300/**
3301 * idpf_get_vec_ids - Initialize vector id from Mailbox parameters
3302 * @adapter: adapter structure to get the mailbox vector id
3303 * @vecids: Array of vector ids
3304 * @num_vecids: number of vector ids
3305 * @chunks: vector ids received over mailbox
3306 *
3307 * Will initialize the mailbox vector id which is received from the
3308 * get capabilities and data queue vector ids with ids received as
3309 * mailbox parameters.
3310 * Returns number of ids filled
3311 */
3312int idpf_get_vec_ids(struct idpf_adapter *adapter,
3313 u16 *vecids, int num_vecids,
3314 struct virtchnl2_vector_chunks *chunks)
3315{
3316 u16 num_chunks = le16_to_cpu(chunks->num_vchunks);
3317 int num_vecid_filled = 0;
3318 int i, j;
3319
3320 vecids[num_vecid_filled] = adapter->mb_vector.v_idx;
3321 num_vecid_filled++;
3322
3323 for (j = 0; j < num_chunks; j++) {
3324 struct virtchnl2_vector_chunk *chunk;
3325 u16 start_vecid, num_vec;
3326
3327 chunk = &chunks->vchunks[j];
3328 num_vec = le16_to_cpu(chunk->num_vectors);
3329 start_vecid = le16_to_cpu(chunk->start_vector_id);
3330
3331 for (i = 0; i < num_vec; i++) {
3332 if ((num_vecid_filled + i) < num_vecids) {
3333 vecids[num_vecid_filled + i] = start_vecid;
3334 start_vecid++;
3335 } else {
3336 break;
3337 }
3338 }
3339 num_vecid_filled = num_vecid_filled + i;
3340 }
3341
3342 return num_vecid_filled;
3343}
3344
3345/**
3346 * idpf_vport_get_queue_ids - Initialize queue id from Mailbox parameters
3347 * @qids: Array of queue ids
3348 * @num_qids: number of queue ids
3349 * @q_type: queue model
3350 * @chunks: queue ids received over mailbox
3351 *
3352 * Will initialize all queue ids with ids received as mailbox parameters
3353 * Returns number of ids filled
3354 */
3355static int idpf_vport_get_queue_ids(u32 *qids, int num_qids, u16 q_type,
3356 struct virtchnl2_queue_reg_chunks *chunks)
3357{
3358 u16 num_chunks = le16_to_cpu(chunks->num_chunks);
3359 u32 num_q_id_filled = 0, i;
3360 u32 start_q_id, num_q;
3361
3362 while (num_chunks--) {
3363 struct virtchnl2_queue_reg_chunk *chunk;
3364
3365 chunk = &chunks->chunks[num_chunks];
3366 if (le32_to_cpu(chunk->type) != q_type)
3367 continue;
3368
3369 num_q = le32_to_cpu(chunk->num_queues);
3370 start_q_id = le32_to_cpu(chunk->start_queue_id);
3371
3372 for (i = 0; i < num_q; i++) {
3373 if ((num_q_id_filled + i) < num_qids) {
3374 qids[num_q_id_filled + i] = start_q_id;
3375 start_q_id++;
3376 } else {
3377 break;
3378 }
3379 }
3380 num_q_id_filled = num_q_id_filled + i;
3381 }
3382
3383 return num_q_id_filled;
3384}
3385
3386/**
3387 * __idpf_vport_queue_ids_init - Initialize queue ids from Mailbox parameters
3388 * @vport: virtual port for which the queues ids are initialized
3389 * @qids: queue ids
3390 * @num_qids: number of queue ids
3391 * @q_type: type of queue
3392 *
3393 * Will initialize all queue ids with ids received as mailbox
3394 * parameters. Returns number of queue ids initialized.
3395 */
3396static int __idpf_vport_queue_ids_init(struct idpf_vport *vport,
3397 const u32 *qids,
3398 int num_qids,
3399 u32 q_type)
3400{
3401 struct idpf_queue *q;
3402 int i, j, k = 0;
3403
3404 switch (q_type) {
3405 case VIRTCHNL2_QUEUE_TYPE_TX:
3406 for (i = 0; i < vport->num_txq_grp; i++) {
3407 struct idpf_txq_group *tx_qgrp = &vport->txq_grps[i];
3408
3409 for (j = 0; j < tx_qgrp->num_txq && k < num_qids; j++, k++) {
3410 tx_qgrp->txqs[j]->q_id = qids[k];
3411 tx_qgrp->txqs[j]->q_type =
3412 VIRTCHNL2_QUEUE_TYPE_TX;
3413 }
3414 }
3415 break;
3416 case VIRTCHNL2_QUEUE_TYPE_RX:
3417 for (i = 0; i < vport->num_rxq_grp; i++) {
3418 struct idpf_rxq_group *rx_qgrp = &vport->rxq_grps[i];
3419 u16 num_rxq;
3420
3421 if (idpf_is_queue_model_split(vport->rxq_model))
3422 num_rxq = rx_qgrp->splitq.num_rxq_sets;
3423 else
3424 num_rxq = rx_qgrp->singleq.num_rxq;
3425
3426 for (j = 0; j < num_rxq && k < num_qids; j++, k++) {
3427 if (idpf_is_queue_model_split(vport->rxq_model))
3428 q = &rx_qgrp->splitq.rxq_sets[j]->rxq;
3429 else
3430 q = rx_qgrp->singleq.rxqs[j];
3431 q->q_id = qids[k];
3432 q->q_type = VIRTCHNL2_QUEUE_TYPE_RX;
3433 }
3434 }
3435 break;
3436 case VIRTCHNL2_QUEUE_TYPE_TX_COMPLETION:
3437 for (i = 0; i < vport->num_txq_grp && k < num_qids; i++, k++) {
3438 struct idpf_txq_group *tx_qgrp = &vport->txq_grps[i];
3439
3440 tx_qgrp->complq->q_id = qids[k];
3441 tx_qgrp->complq->q_type =
3442 VIRTCHNL2_QUEUE_TYPE_TX_COMPLETION;
3443 }
3444 break;
3445 case VIRTCHNL2_QUEUE_TYPE_RX_BUFFER:
3446 for (i = 0; i < vport->num_rxq_grp; i++) {
3447 struct idpf_rxq_group *rx_qgrp = &vport->rxq_grps[i];
3448 u8 num_bufqs = vport->num_bufqs_per_qgrp;
3449
3450 for (j = 0; j < num_bufqs && k < num_qids; j++, k++) {
3451 q = &rx_qgrp->splitq.bufq_sets[j].bufq;
3452 q->q_id = qids[k];
3453 q->q_type = VIRTCHNL2_QUEUE_TYPE_RX_BUFFER;
3454 }
3455 }
3456 break;
3457 default:
3458 break;
3459 }
3460
3461 return k;
3462}
3463
3464/**
3465 * idpf_vport_queue_ids_init - Initialize queue ids from Mailbox parameters
3466 * @vport: virtual port for which the queues ids are initialized
3467 *
3468 * Will initialize all queue ids with ids received as mailbox parameters.
3469 * Returns 0 on success, negative if all the queues are not initialized.
3470 */
3471int idpf_vport_queue_ids_init(struct idpf_vport *vport)
3472{
3473 struct virtchnl2_create_vport *vport_params;
3474 struct virtchnl2_queue_reg_chunks *chunks;
3475 struct idpf_vport_config *vport_config;
3476 u16 vport_idx = vport->idx;
3477 int num_ids, err = 0;
3478 u16 q_type;
3479 u32 *qids;
3480
3481 vport_config = vport->adapter->vport_config[vport_idx];
3482 if (vport_config->req_qs_chunks) {
3483 struct virtchnl2_add_queues *vc_aq =
3484 (struct virtchnl2_add_queues *)vport_config->req_qs_chunks;
3485 chunks = &vc_aq->chunks;
3486 } else {
3487 vport_params = vport->adapter->vport_params_recvd[vport_idx];
3488 chunks = &vport_params->chunks;
3489 }
3490
3491 qids = kcalloc(IDPF_MAX_QIDS, sizeof(u32), GFP_KERNEL);
3492 if (!qids)
3493 return -ENOMEM;
3494
3495 num_ids = idpf_vport_get_queue_ids(qids, IDPF_MAX_QIDS,
3496 VIRTCHNL2_QUEUE_TYPE_TX,
3497 chunks);
3498 if (num_ids < vport->num_txq) {
3499 err = -EINVAL;
3500 goto mem_rel;
3501 }
3502 num_ids = __idpf_vport_queue_ids_init(vport, qids, num_ids,
3503 VIRTCHNL2_QUEUE_TYPE_TX);
3504 if (num_ids < vport->num_txq) {
3505 err = -EINVAL;
3506 goto mem_rel;
3507 }
3508
3509 num_ids = idpf_vport_get_queue_ids(qids, IDPF_MAX_QIDS,
3510 VIRTCHNL2_QUEUE_TYPE_RX,
3511 chunks);
3512 if (num_ids < vport->num_rxq) {
3513 err = -EINVAL;
3514 goto mem_rel;
3515 }
3516 num_ids = __idpf_vport_queue_ids_init(vport, qids, num_ids,
3517 VIRTCHNL2_QUEUE_TYPE_RX);
3518 if (num_ids < vport->num_rxq) {
3519 err = -EINVAL;
3520 goto mem_rel;
3521 }
3522
3523 if (!idpf_is_queue_model_split(vport->txq_model))
3524 goto check_rxq;
3525
3526 q_type = VIRTCHNL2_QUEUE_TYPE_TX_COMPLETION;
3527 num_ids = idpf_vport_get_queue_ids(qids, IDPF_MAX_QIDS, q_type, chunks);
3528 if (num_ids < vport->num_complq) {
3529 err = -EINVAL;
3530 goto mem_rel;
3531 }
3532 num_ids = __idpf_vport_queue_ids_init(vport, qids, num_ids, q_type);
3533 if (num_ids < vport->num_complq) {
3534 err = -EINVAL;
3535 goto mem_rel;
3536 }
3537
3538check_rxq:
3539 if (!idpf_is_queue_model_split(vport->rxq_model))
3540 goto mem_rel;
3541
3542 q_type = VIRTCHNL2_QUEUE_TYPE_RX_BUFFER;
3543 num_ids = idpf_vport_get_queue_ids(qids, IDPF_MAX_QIDS, q_type, chunks);
3544 if (num_ids < vport->num_bufq) {
3545 err = -EINVAL;
3546 goto mem_rel;
3547 }
3548 num_ids = __idpf_vport_queue_ids_init(vport, qids, num_ids, q_type);
3549 if (num_ids < vport->num_bufq)
3550 err = -EINVAL;
3551
3552mem_rel:
3553 kfree(qids);
3554
3555 return err;
3556}
3557
3558/**
3559 * idpf_vport_adjust_qs - Adjust to new requested queues
3560 * @vport: virtual port data struct
3561 *
3562 * Renegotiate queues. Returns 0 on success, negative on failure.
3563 */
3564int idpf_vport_adjust_qs(struct idpf_vport *vport)
3565{
3566 struct virtchnl2_create_vport vport_msg;
3567 int err;
3568
3569 vport_msg.txq_model = cpu_to_le16(vport->txq_model);
3570 vport_msg.rxq_model = cpu_to_le16(vport->rxq_model);
3571 err = idpf_vport_calc_total_qs(vport->adapter, vport->idx, &vport_msg,
3572 NULL);
3573 if (err)
3574 return err;
3575
3576 idpf_vport_init_num_qs(vport, &vport_msg);
3577 idpf_vport_calc_num_q_groups(vport);
3578
3579 return 0;
3580}
3581
3582/**
3583 * idpf_is_capability_ena - Default implementation of capability checking
3584 * @adapter: Private data struct
3585 * @all: all or one flag
3586 * @field: caps field to check for flags
3587 * @flag: flag to check
3588 *
3589 * Return true if all capabilities are supported, false otherwise
3590 */
3591bool idpf_is_capability_ena(struct idpf_adapter *adapter, bool all,
3592 enum idpf_cap_field field, u64 flag)
3593{
3594 u8 *caps = (u8 *)&adapter->caps;
3595 u32 *cap_field;
3596
3597 if (!caps)
3598 return false;
3599
3600 if (field == IDPF_BASE_CAPS)
3601 return false;
3602
3603 cap_field = (u32 *)(caps + field);
3604
3605 if (all)
3606 return (*cap_field & flag) == flag;
3607 else
3608 return !!(*cap_field & flag);
3609}
3610
3611/**
3612 * idpf_get_vport_id: Get vport id
3613 * @vport: virtual port structure
3614 *
3615 * Return vport id from the adapter persistent data
3616 */
3617u32 idpf_get_vport_id(struct idpf_vport *vport)
3618{
3619 struct virtchnl2_create_vport *vport_msg;
3620
3621 vport_msg = vport->adapter->vport_params_recvd[vport->idx];
3622
3623 return le32_to_cpu(vport_msg->vport_id);
3624}
3625
3626/**
3627 * idpf_add_del_mac_filters - Add/del mac filters
3628 * @vport: Virtual port data structure
3629 * @np: Netdev private structure
3630 * @add: Add or delete flag
3631 * @async: Don't wait for return message
3632 *
3633 * Returns 0 on success, error on failure.
3634 **/
3635int idpf_add_del_mac_filters(struct idpf_vport *vport,
3636 struct idpf_netdev_priv *np,
3637 bool add, bool async)
3638{
3639 struct virtchnl2_mac_addr_list *ma_list = NULL;
3640 struct idpf_adapter *adapter = np->adapter;
3641 struct idpf_vport_config *vport_config;
3642 enum idpf_vport_config_flags mac_flag;
3643 struct pci_dev *pdev = adapter->pdev;
3644 enum idpf_vport_vc_state vc, vc_err;
3645 struct virtchnl2_mac_addr *mac_addr;
3646 struct idpf_mac_filter *f, *tmp;
3647 u32 num_msgs, total_filters = 0;
3648 int i = 0, k, err = 0;
3649 u32 vop;
3650
3651 vport_config = adapter->vport_config[np->vport_idx];
3652 spin_lock_bh(&vport_config->mac_filter_list_lock);
3653
3654 /* Find the number of newly added filters */
3655 list_for_each_entry(f, &vport_config->user_config.mac_filter_list,
3656 list) {
3657 if (add && f->add)
3658 total_filters++;
3659 else if (!add && f->remove)
3660 total_filters++;
3661 }
3662
3663 if (!total_filters) {
3664 spin_unlock_bh(&vport_config->mac_filter_list_lock);
3665
3666 return 0;
3667 }
3668
3669 /* Fill all the new filters into virtchannel message */
3670 mac_addr = kcalloc(total_filters, sizeof(struct virtchnl2_mac_addr),
3671 GFP_ATOMIC);
3672 if (!mac_addr) {
3673 err = -ENOMEM;
3674 spin_unlock_bh(&vport_config->mac_filter_list_lock);
3675 goto error;
3676 }
3677
3678 list_for_each_entry_safe(f, tmp, &vport_config->user_config.mac_filter_list,
3679 list) {
3680 if (add && f->add) {
3681 ether_addr_copy(mac_addr[i].addr, f->macaddr);
3682 i++;
3683 f->add = false;
3684 if (i == total_filters)
3685 break;
3686 }
3687 if (!add && f->remove) {
3688 ether_addr_copy(mac_addr[i].addr, f->macaddr);
3689 i++;
3690 f->remove = false;
3691 if (i == total_filters)
3692 break;
3693 }
3694 }
3695
3696 spin_unlock_bh(&vport_config->mac_filter_list_lock);
3697
3698 if (add) {
3699 vop = VIRTCHNL2_OP_ADD_MAC_ADDR;
3700 vc = IDPF_VC_ADD_MAC_ADDR;
3701 vc_err = IDPF_VC_ADD_MAC_ADDR_ERR;
3702 mac_flag = IDPF_VPORT_ADD_MAC_REQ;
3703 } else {
3704 vop = VIRTCHNL2_OP_DEL_MAC_ADDR;
3705 vc = IDPF_VC_DEL_MAC_ADDR;
3706 vc_err = IDPF_VC_DEL_MAC_ADDR_ERR;
3707 mac_flag = IDPF_VPORT_DEL_MAC_REQ;
3708 }
3709
3710 /* Chunk up the filters into multiple messages to avoid
3711 * sending a control queue message buffer that is too large
3712 */
3713 num_msgs = DIV_ROUND_UP(total_filters, IDPF_NUM_FILTERS_PER_MSG);
3714
3715 if (!async)
3716 mutex_lock(&vport->vc_buf_lock);
3717
3718 for (i = 0, k = 0; i < num_msgs; i++) {
3719 u32 entries_size, buf_size, num_entries;
3720
3721 num_entries = min_t(u32, total_filters,
3722 IDPF_NUM_FILTERS_PER_MSG);
3723 entries_size = sizeof(struct virtchnl2_mac_addr) * num_entries;
3724 buf_size = struct_size(ma_list, mac_addr_list, num_entries);
3725
3726 if (!ma_list || num_entries != IDPF_NUM_FILTERS_PER_MSG) {
3727 kfree(ma_list);
3728 ma_list = kzalloc(buf_size, GFP_ATOMIC);
3729 if (!ma_list) {
3730 err = -ENOMEM;
3731 goto list_prep_error;
3732 }
3733 } else {
3734 memset(ma_list, 0, buf_size);
3735 }
3736
3737 ma_list->vport_id = cpu_to_le32(np->vport_id);
3738 ma_list->num_mac_addr = cpu_to_le16(num_entries);
3739 memcpy(ma_list->mac_addr_list, &mac_addr[k], entries_size);
3740
3741 if (async)
3742 set_bit(mac_flag, vport_config->flags);
3743
3744 err = idpf_send_mb_msg(adapter, vop, buf_size, (u8 *)ma_list);
3745 if (err)
3746 goto mbx_error;
3747
3748 if (!async) {
3749 err = idpf_wait_for_event(adapter, vport, vc, vc_err);
3750 if (err)
3751 goto mbx_error;
3752 }
3753
3754 k += num_entries;
3755 total_filters -= num_entries;
3756 }
3757
3758mbx_error:
3759 if (!async)
3760 mutex_unlock(&vport->vc_buf_lock);
3761 kfree(ma_list);
3762list_prep_error:
3763 kfree(mac_addr);
3764error:
3765 if (err)
3766 dev_err(&pdev->dev, "Failed to add or del mac filters %d", err);
3767
3768 return err;
3769}
3770
3771/**
3772 * idpf_set_promiscuous - set promiscuous and send message to mailbox
3773 * @adapter: Driver specific private structure
3774 * @config_data: Vport specific config data
3775 * @vport_id: Vport identifier
3776 *
3777 * Request to enable promiscuous mode for the vport. Message is sent
3778 * asynchronously and won't wait for response. Returns 0 on success, negative
3779 * on failure;
3780 */
3781int idpf_set_promiscuous(struct idpf_adapter *adapter,
3782 struct idpf_vport_user_config_data *config_data,
3783 u32 vport_id)
3784{
3785 struct virtchnl2_promisc_info vpi;
3786 u16 flags = 0;
3787 int err;
3788
3789 if (test_bit(__IDPF_PROMISC_UC, config_data->user_flags))
3790 flags |= VIRTCHNL2_UNICAST_PROMISC;
3791 if (test_bit(__IDPF_PROMISC_MC, config_data->user_flags))
3792 flags |= VIRTCHNL2_MULTICAST_PROMISC;
3793
3794 vpi.vport_id = cpu_to_le32(vport_id);
3795 vpi.flags = cpu_to_le16(flags);
3796
3797 err = idpf_send_mb_msg(adapter, VIRTCHNL2_OP_CONFIG_PROMISCUOUS_MODE,
3798 sizeof(struct virtchnl2_promisc_info),
3799 (u8 *)&vpi);
3800
3801 return err;
3802}