xref: /linux/drivers/net/ethernet/intel/idpf/idpf_lib.c (revision 1d5198dd08ac04b13a8b7539131baf0980998032)
1 // SPDX-License-Identifier: GPL-2.0-only
2 /* Copyright (C) 2023 Intel Corporation */
3 
4 #include "idpf.h"
5 #include "idpf_virtchnl.h"
6 
7 static const struct net_device_ops idpf_netdev_ops_splitq;
8 static const struct net_device_ops idpf_netdev_ops_singleq;
9 
10 /**
11  * idpf_init_vector_stack - Fill the MSIX vector stack with vector index
12  * @adapter: private data struct
13  *
14  * Return 0 on success, error on failure
15  */
16 static int idpf_init_vector_stack(struct idpf_adapter *adapter)
17 {
18 	struct idpf_vector_lifo *stack;
19 	u16 min_vec;
20 	u32 i;
21 
22 	mutex_lock(&adapter->vector_lock);
23 	min_vec = adapter->num_msix_entries - adapter->num_avail_msix;
24 	stack = &adapter->vector_stack;
25 	stack->size = adapter->num_msix_entries;
26 	/* set the base and top to point at start of the 'free pool' to
27 	 * distribute the unused vectors on-demand basis
28 	 */
29 	stack->base = min_vec;
30 	stack->top = min_vec;
31 
32 	stack->vec_idx = kcalloc(stack->size, sizeof(u16), GFP_KERNEL);
33 	if (!stack->vec_idx) {
34 		mutex_unlock(&adapter->vector_lock);
35 
36 		return -ENOMEM;
37 	}
38 
39 	for (i = 0; i < stack->size; i++)
40 		stack->vec_idx[i] = i;
41 
42 	mutex_unlock(&adapter->vector_lock);
43 
44 	return 0;
45 }
46 
47 /**
48  * idpf_deinit_vector_stack - zero out the MSIX vector stack
49  * @adapter: private data struct
50  */
51 static void idpf_deinit_vector_stack(struct idpf_adapter *adapter)
52 {
53 	struct idpf_vector_lifo *stack;
54 
55 	mutex_lock(&adapter->vector_lock);
56 	stack = &adapter->vector_stack;
57 	kfree(stack->vec_idx);
58 	stack->vec_idx = NULL;
59 	mutex_unlock(&adapter->vector_lock);
60 }
61 
62 /**
63  * idpf_mb_intr_rel_irq - Free the IRQ association with the OS
64  * @adapter: adapter structure
65  *
66  * This will also disable interrupt mode and queue up mailbox task. Mailbox
67  * task will reschedule itself if not in interrupt mode.
68  */
69 static void idpf_mb_intr_rel_irq(struct idpf_adapter *adapter)
70 {
71 	clear_bit(IDPF_MB_INTR_MODE, adapter->flags);
72 	free_irq(adapter->msix_entries[0].vector, adapter);
73 	queue_delayed_work(adapter->mbx_wq, &adapter->mbx_task, 0);
74 }
75 
76 /**
77  * idpf_intr_rel - Release interrupt capabilities and free memory
78  * @adapter: adapter to disable interrupts on
79  */
80 void idpf_intr_rel(struct idpf_adapter *adapter)
81 {
82 	if (!adapter->msix_entries)
83 		return;
84 
85 	idpf_mb_intr_rel_irq(adapter);
86 	pci_free_irq_vectors(adapter->pdev);
87 	idpf_send_dealloc_vectors_msg(adapter);
88 	idpf_deinit_vector_stack(adapter);
89 	kfree(adapter->msix_entries);
90 	adapter->msix_entries = NULL;
91 }
92 
93 /**
94  * idpf_mb_intr_clean - Interrupt handler for the mailbox
95  * @irq: interrupt number
96  * @data: pointer to the adapter structure
97  */
98 static irqreturn_t idpf_mb_intr_clean(int __always_unused irq, void *data)
99 {
100 	struct idpf_adapter *adapter = (struct idpf_adapter *)data;
101 
102 	queue_delayed_work(adapter->mbx_wq, &adapter->mbx_task, 0);
103 
104 	return IRQ_HANDLED;
105 }
106 
107 /**
108  * idpf_mb_irq_enable - Enable MSIX interrupt for the mailbox
109  * @adapter: adapter to get the hardware address for register write
110  */
111 static void idpf_mb_irq_enable(struct idpf_adapter *adapter)
112 {
113 	struct idpf_intr_reg *intr = &adapter->mb_vector.intr_reg;
114 	u32 val;
115 
116 	val = intr->dyn_ctl_intena_m | intr->dyn_ctl_itridx_m;
117 	writel(val, intr->dyn_ctl);
118 	writel(intr->icr_ena_ctlq_m, intr->icr_ena);
119 }
120 
121 /**
122  * idpf_mb_intr_req_irq - Request irq for the mailbox interrupt
123  * @adapter: adapter structure to pass to the mailbox irq handler
124  */
125 static int idpf_mb_intr_req_irq(struct idpf_adapter *adapter)
126 {
127 	struct idpf_q_vector *mb_vector = &adapter->mb_vector;
128 	int irq_num, mb_vidx = 0, err;
129 
130 	irq_num = adapter->msix_entries[mb_vidx].vector;
131 	mb_vector->name = kasprintf(GFP_KERNEL, "%s-%s-%d",
132 				    dev_driver_string(&adapter->pdev->dev),
133 				    "Mailbox", mb_vidx);
134 	err = request_irq(irq_num, adapter->irq_mb_handler, 0,
135 			  mb_vector->name, adapter);
136 	if (err) {
137 		dev_err(&adapter->pdev->dev,
138 			"IRQ request for mailbox failed, error: %d\n", err);
139 
140 		return err;
141 	}
142 
143 	set_bit(IDPF_MB_INTR_MODE, adapter->flags);
144 
145 	return 0;
146 }
147 
148 /**
149  * idpf_set_mb_vec_id - Set vector index for mailbox
150  * @adapter: adapter structure to access the vector chunks
151  *
152  * The first vector id in the requested vector chunks from the CP is for
153  * the mailbox
154  */
155 static void idpf_set_mb_vec_id(struct idpf_adapter *adapter)
156 {
157 	if (adapter->req_vec_chunks)
158 		adapter->mb_vector.v_idx =
159 			le16_to_cpu(adapter->caps.mailbox_vector_id);
160 	else
161 		adapter->mb_vector.v_idx = 0;
162 }
163 
164 /**
165  * idpf_mb_intr_init - Initialize the mailbox interrupt
166  * @adapter: adapter structure to store the mailbox vector
167  */
168 static int idpf_mb_intr_init(struct idpf_adapter *adapter)
169 {
170 	adapter->dev_ops.reg_ops.mb_intr_reg_init(adapter);
171 	adapter->irq_mb_handler = idpf_mb_intr_clean;
172 
173 	return idpf_mb_intr_req_irq(adapter);
174 }
175 
176 /**
177  * idpf_vector_lifo_push - push MSIX vector index onto stack
178  * @adapter: private data struct
179  * @vec_idx: vector index to store
180  */
181 static int idpf_vector_lifo_push(struct idpf_adapter *adapter, u16 vec_idx)
182 {
183 	struct idpf_vector_lifo *stack = &adapter->vector_stack;
184 
185 	lockdep_assert_held(&adapter->vector_lock);
186 
187 	if (stack->top == stack->base) {
188 		dev_err(&adapter->pdev->dev, "Exceeded the vector stack limit: %d\n",
189 			stack->top);
190 		return -EINVAL;
191 	}
192 
193 	stack->vec_idx[--stack->top] = vec_idx;
194 
195 	return 0;
196 }
197 
198 /**
199  * idpf_vector_lifo_pop - pop MSIX vector index from stack
200  * @adapter: private data struct
201  */
202 static int idpf_vector_lifo_pop(struct idpf_adapter *adapter)
203 {
204 	struct idpf_vector_lifo *stack = &adapter->vector_stack;
205 
206 	lockdep_assert_held(&adapter->vector_lock);
207 
208 	if (stack->top == stack->size) {
209 		dev_err(&adapter->pdev->dev, "No interrupt vectors are available to distribute!\n");
210 
211 		return -EINVAL;
212 	}
213 
214 	return stack->vec_idx[stack->top++];
215 }
216 
217 /**
218  * idpf_vector_stash - Store the vector indexes onto the stack
219  * @adapter: private data struct
220  * @q_vector_idxs: vector index array
221  * @vec_info: info related to the number of vectors
222  *
223  * This function is a no-op if there are no vectors indexes to be stashed
224  */
225 static void idpf_vector_stash(struct idpf_adapter *adapter, u16 *q_vector_idxs,
226 			      struct idpf_vector_info *vec_info)
227 {
228 	int i, base = 0;
229 	u16 vec_idx;
230 
231 	lockdep_assert_held(&adapter->vector_lock);
232 
233 	if (!vec_info->num_curr_vecs)
234 		return;
235 
236 	/* For default vports, no need to stash vector allocated from the
237 	 * default pool onto the stack
238 	 */
239 	if (vec_info->default_vport)
240 		base = IDPF_MIN_Q_VEC;
241 
242 	for (i = vec_info->num_curr_vecs - 1; i >= base ; i--) {
243 		vec_idx = q_vector_idxs[i];
244 		idpf_vector_lifo_push(adapter, vec_idx);
245 		adapter->num_avail_msix++;
246 	}
247 }
248 
249 /**
250  * idpf_req_rel_vector_indexes - Request or release MSIX vector indexes
251  * @adapter: driver specific private structure
252  * @q_vector_idxs: vector index array
253  * @vec_info: info related to the number of vectors
254  *
255  * This is the core function to distribute the MSIX vectors acquired from the
256  * OS. It expects the caller to pass the number of vectors required and
257  * also previously allocated. First, it stashes previously allocated vector
258  * indexes on to the stack and then figures out if it can allocate requested
259  * vectors. It can wait on acquiring the mutex lock. If the caller passes 0 as
260  * requested vectors, then this function just stashes the already allocated
261  * vectors and returns 0.
262  *
263  * Returns actual number of vectors allocated on success, error value on failure
264  * If 0 is returned, implies the stack has no vectors to allocate which is also
265  * a failure case for the caller
266  */
267 int idpf_req_rel_vector_indexes(struct idpf_adapter *adapter,
268 				u16 *q_vector_idxs,
269 				struct idpf_vector_info *vec_info)
270 {
271 	u16 num_req_vecs, num_alloc_vecs = 0, max_vecs;
272 	struct idpf_vector_lifo *stack;
273 	int i, j, vecid;
274 
275 	mutex_lock(&adapter->vector_lock);
276 	stack = &adapter->vector_stack;
277 	num_req_vecs = vec_info->num_req_vecs;
278 
279 	/* Stash interrupt vector indexes onto the stack if required */
280 	idpf_vector_stash(adapter, q_vector_idxs, vec_info);
281 
282 	if (!num_req_vecs)
283 		goto rel_lock;
284 
285 	if (vec_info->default_vport) {
286 		/* As IDPF_MIN_Q_VEC per default vport is put aside in the
287 		 * default pool of the stack, use them for default vports
288 		 */
289 		j = vec_info->index * IDPF_MIN_Q_VEC + IDPF_MBX_Q_VEC;
290 		for (i = 0; i < IDPF_MIN_Q_VEC; i++) {
291 			q_vector_idxs[num_alloc_vecs++] = stack->vec_idx[j++];
292 			num_req_vecs--;
293 		}
294 	}
295 
296 	/* Find if stack has enough vector to allocate */
297 	max_vecs = min(adapter->num_avail_msix, num_req_vecs);
298 
299 	for (j = 0; j < max_vecs; j++) {
300 		vecid = idpf_vector_lifo_pop(adapter);
301 		q_vector_idxs[num_alloc_vecs++] = vecid;
302 	}
303 	adapter->num_avail_msix -= max_vecs;
304 
305 rel_lock:
306 	mutex_unlock(&adapter->vector_lock);
307 
308 	return num_alloc_vecs;
309 }
310 
311 /**
312  * idpf_intr_req - Request interrupt capabilities
313  * @adapter: adapter to enable interrupts on
314  *
315  * Returns 0 on success, negative on failure
316  */
317 int idpf_intr_req(struct idpf_adapter *adapter)
318 {
319 	u16 default_vports = idpf_get_default_vports(adapter);
320 	int num_q_vecs, total_vecs, num_vec_ids;
321 	int min_vectors, v_actual, err;
322 	unsigned int vector;
323 	u16 *vecids;
324 
325 	total_vecs = idpf_get_reserved_vecs(adapter);
326 	num_q_vecs = total_vecs - IDPF_MBX_Q_VEC;
327 
328 	err = idpf_send_alloc_vectors_msg(adapter, num_q_vecs);
329 	if (err) {
330 		dev_err(&adapter->pdev->dev,
331 			"Failed to allocate %d vectors: %d\n", num_q_vecs, err);
332 
333 		return -EAGAIN;
334 	}
335 
336 	min_vectors = IDPF_MBX_Q_VEC + IDPF_MIN_Q_VEC * default_vports;
337 	v_actual = pci_alloc_irq_vectors(adapter->pdev, min_vectors,
338 					 total_vecs, PCI_IRQ_MSIX);
339 	if (v_actual < min_vectors) {
340 		dev_err(&adapter->pdev->dev, "Failed to allocate MSIX vectors: %d\n",
341 			v_actual);
342 		err = -EAGAIN;
343 		goto send_dealloc_vecs;
344 	}
345 
346 	adapter->msix_entries = kcalloc(v_actual, sizeof(struct msix_entry),
347 					GFP_KERNEL);
348 
349 	if (!adapter->msix_entries) {
350 		err = -ENOMEM;
351 		goto free_irq;
352 	}
353 
354 	idpf_set_mb_vec_id(adapter);
355 
356 	vecids = kcalloc(total_vecs, sizeof(u16), GFP_KERNEL);
357 	if (!vecids) {
358 		err = -ENOMEM;
359 		goto free_msix;
360 	}
361 
362 	if (adapter->req_vec_chunks) {
363 		struct virtchnl2_vector_chunks *vchunks;
364 		struct virtchnl2_alloc_vectors *ac;
365 
366 		ac = adapter->req_vec_chunks;
367 		vchunks = &ac->vchunks;
368 
369 		num_vec_ids = idpf_get_vec_ids(adapter, vecids, total_vecs,
370 					       vchunks);
371 		if (num_vec_ids < v_actual) {
372 			err = -EINVAL;
373 			goto free_vecids;
374 		}
375 	} else {
376 		int i;
377 
378 		for (i = 0; i < v_actual; i++)
379 			vecids[i] = i;
380 	}
381 
382 	for (vector = 0; vector < v_actual; vector++) {
383 		adapter->msix_entries[vector].entry = vecids[vector];
384 		adapter->msix_entries[vector].vector =
385 			pci_irq_vector(adapter->pdev, vector);
386 	}
387 
388 	adapter->num_req_msix = total_vecs;
389 	adapter->num_msix_entries = v_actual;
390 	/* 'num_avail_msix' is used to distribute excess vectors to the vports
391 	 * after considering the minimum vectors required per each default
392 	 * vport
393 	 */
394 	adapter->num_avail_msix = v_actual - min_vectors;
395 
396 	/* Fill MSIX vector lifo stack with vector indexes */
397 	err = idpf_init_vector_stack(adapter);
398 	if (err)
399 		goto free_vecids;
400 
401 	err = idpf_mb_intr_init(adapter);
402 	if (err)
403 		goto deinit_vec_stack;
404 	idpf_mb_irq_enable(adapter);
405 	kfree(vecids);
406 
407 	return 0;
408 
409 deinit_vec_stack:
410 	idpf_deinit_vector_stack(adapter);
411 free_vecids:
412 	kfree(vecids);
413 free_msix:
414 	kfree(adapter->msix_entries);
415 	adapter->msix_entries = NULL;
416 free_irq:
417 	pci_free_irq_vectors(adapter->pdev);
418 send_dealloc_vecs:
419 	idpf_send_dealloc_vectors_msg(adapter);
420 
421 	return err;
422 }
423 
424 /**
425  * idpf_find_mac_filter - Search filter list for specific mac filter
426  * @vconfig: Vport config structure
427  * @macaddr: The MAC address
428  *
429  * Returns ptr to the filter object or NULL. Must be called while holding the
430  * mac_filter_list_lock.
431  **/
432 static struct idpf_mac_filter *idpf_find_mac_filter(struct idpf_vport_config *vconfig,
433 						    const u8 *macaddr)
434 {
435 	struct idpf_mac_filter *f;
436 
437 	if (!macaddr)
438 		return NULL;
439 
440 	list_for_each_entry(f, &vconfig->user_config.mac_filter_list, list) {
441 		if (ether_addr_equal(macaddr, f->macaddr))
442 			return f;
443 	}
444 
445 	return NULL;
446 }
447 
448 /**
449  * __idpf_del_mac_filter - Delete a MAC filter from the filter list
450  * @vport_config: Vport config structure
451  * @macaddr: The MAC address
452  *
453  * Returns 0 on success, error value on failure
454  **/
455 static int __idpf_del_mac_filter(struct idpf_vport_config *vport_config,
456 				 const u8 *macaddr)
457 {
458 	struct idpf_mac_filter *f;
459 
460 	spin_lock_bh(&vport_config->mac_filter_list_lock);
461 	f = idpf_find_mac_filter(vport_config, macaddr);
462 	if (f) {
463 		list_del(&f->list);
464 		kfree(f);
465 	}
466 	spin_unlock_bh(&vport_config->mac_filter_list_lock);
467 
468 	return 0;
469 }
470 
471 /**
472  * idpf_del_mac_filter - Delete a MAC filter from the filter list
473  * @vport: Main vport structure
474  * @np: Netdev private structure
475  * @macaddr: The MAC address
476  * @async: Don't wait for return message
477  *
478  * Removes filter from list and if interface is up, tells hardware about the
479  * removed filter.
480  **/
481 static int idpf_del_mac_filter(struct idpf_vport *vport,
482 			       struct idpf_netdev_priv *np,
483 			       const u8 *macaddr, bool async)
484 {
485 	struct idpf_vport_config *vport_config;
486 	struct idpf_mac_filter *f;
487 
488 	vport_config = np->adapter->vport_config[np->vport_idx];
489 
490 	spin_lock_bh(&vport_config->mac_filter_list_lock);
491 	f = idpf_find_mac_filter(vport_config, macaddr);
492 	if (f) {
493 		f->remove = true;
494 	} else {
495 		spin_unlock_bh(&vport_config->mac_filter_list_lock);
496 
497 		return -EINVAL;
498 	}
499 	spin_unlock_bh(&vport_config->mac_filter_list_lock);
500 
501 	if (np->state == __IDPF_VPORT_UP) {
502 		int err;
503 
504 		err = idpf_add_del_mac_filters(vport, np, false, async);
505 		if (err)
506 			return err;
507 	}
508 
509 	return  __idpf_del_mac_filter(vport_config, macaddr);
510 }
511 
512 /**
513  * __idpf_add_mac_filter - Add mac filter helper function
514  * @vport_config: Vport config structure
515  * @macaddr: Address to add
516  *
517  * Takes mac_filter_list_lock spinlock to add new filter to list.
518  */
519 static int __idpf_add_mac_filter(struct idpf_vport_config *vport_config,
520 				 const u8 *macaddr)
521 {
522 	struct idpf_mac_filter *f;
523 
524 	spin_lock_bh(&vport_config->mac_filter_list_lock);
525 
526 	f = idpf_find_mac_filter(vport_config, macaddr);
527 	if (f) {
528 		f->remove = false;
529 		spin_unlock_bh(&vport_config->mac_filter_list_lock);
530 
531 		return 0;
532 	}
533 
534 	f = kzalloc(sizeof(*f), GFP_ATOMIC);
535 	if (!f) {
536 		spin_unlock_bh(&vport_config->mac_filter_list_lock);
537 
538 		return -ENOMEM;
539 	}
540 
541 	ether_addr_copy(f->macaddr, macaddr);
542 	list_add_tail(&f->list, &vport_config->user_config.mac_filter_list);
543 	f->add = true;
544 
545 	spin_unlock_bh(&vport_config->mac_filter_list_lock);
546 
547 	return 0;
548 }
549 
550 /**
551  * idpf_add_mac_filter - Add a mac filter to the filter list
552  * @vport: Main vport structure
553  * @np: Netdev private structure
554  * @macaddr: The MAC address
555  * @async: Don't wait for return message
556  *
557  * Returns 0 on success or error on failure. If interface is up, we'll also
558  * send the virtchnl message to tell hardware about the filter.
559  **/
560 static int idpf_add_mac_filter(struct idpf_vport *vport,
561 			       struct idpf_netdev_priv *np,
562 			       const u8 *macaddr, bool async)
563 {
564 	struct idpf_vport_config *vport_config;
565 	int err;
566 
567 	vport_config = np->adapter->vport_config[np->vport_idx];
568 	err = __idpf_add_mac_filter(vport_config, macaddr);
569 	if (err)
570 		return err;
571 
572 	if (np->state == __IDPF_VPORT_UP)
573 		err = idpf_add_del_mac_filters(vport, np, true, async);
574 
575 	return err;
576 }
577 
578 /**
579  * idpf_del_all_mac_filters - Delete all MAC filters in list
580  * @vport: main vport struct
581  *
582  * Takes mac_filter_list_lock spinlock.  Deletes all filters
583  */
584 static void idpf_del_all_mac_filters(struct idpf_vport *vport)
585 {
586 	struct idpf_vport_config *vport_config;
587 	struct idpf_mac_filter *f, *ftmp;
588 
589 	vport_config = vport->adapter->vport_config[vport->idx];
590 	spin_lock_bh(&vport_config->mac_filter_list_lock);
591 
592 	list_for_each_entry_safe(f, ftmp, &vport_config->user_config.mac_filter_list,
593 				 list) {
594 		list_del(&f->list);
595 		kfree(f);
596 	}
597 
598 	spin_unlock_bh(&vport_config->mac_filter_list_lock);
599 }
600 
601 /**
602  * idpf_restore_mac_filters - Re-add all MAC filters in list
603  * @vport: main vport struct
604  *
605  * Takes mac_filter_list_lock spinlock.  Sets add field to true for filters to
606  * resync filters back to HW.
607  */
608 static void idpf_restore_mac_filters(struct idpf_vport *vport)
609 {
610 	struct idpf_vport_config *vport_config;
611 	struct idpf_mac_filter *f;
612 
613 	vport_config = vport->adapter->vport_config[vport->idx];
614 	spin_lock_bh(&vport_config->mac_filter_list_lock);
615 
616 	list_for_each_entry(f, &vport_config->user_config.mac_filter_list, list)
617 		f->add = true;
618 
619 	spin_unlock_bh(&vport_config->mac_filter_list_lock);
620 
621 	idpf_add_del_mac_filters(vport, netdev_priv(vport->netdev),
622 				 true, false);
623 }
624 
625 /**
626  * idpf_remove_mac_filters - Remove all MAC filters in list
627  * @vport: main vport struct
628  *
629  * Takes mac_filter_list_lock spinlock. Sets remove field to true for filters
630  * to remove filters in HW.
631  */
632 static void idpf_remove_mac_filters(struct idpf_vport *vport)
633 {
634 	struct idpf_vport_config *vport_config;
635 	struct idpf_mac_filter *f;
636 
637 	vport_config = vport->adapter->vport_config[vport->idx];
638 	spin_lock_bh(&vport_config->mac_filter_list_lock);
639 
640 	list_for_each_entry(f, &vport_config->user_config.mac_filter_list, list)
641 		f->remove = true;
642 
643 	spin_unlock_bh(&vport_config->mac_filter_list_lock);
644 
645 	idpf_add_del_mac_filters(vport, netdev_priv(vport->netdev),
646 				 false, false);
647 }
648 
649 /**
650  * idpf_deinit_mac_addr - deinitialize mac address for vport
651  * @vport: main vport structure
652  */
653 static void idpf_deinit_mac_addr(struct idpf_vport *vport)
654 {
655 	struct idpf_vport_config *vport_config;
656 	struct idpf_mac_filter *f;
657 
658 	vport_config = vport->adapter->vport_config[vport->idx];
659 
660 	spin_lock_bh(&vport_config->mac_filter_list_lock);
661 
662 	f = idpf_find_mac_filter(vport_config, vport->default_mac_addr);
663 	if (f) {
664 		list_del(&f->list);
665 		kfree(f);
666 	}
667 
668 	spin_unlock_bh(&vport_config->mac_filter_list_lock);
669 }
670 
671 /**
672  * idpf_init_mac_addr - initialize mac address for vport
673  * @vport: main vport structure
674  * @netdev: pointer to netdev struct associated with this vport
675  */
676 static int idpf_init_mac_addr(struct idpf_vport *vport,
677 			      struct net_device *netdev)
678 {
679 	struct idpf_netdev_priv *np = netdev_priv(netdev);
680 	struct idpf_adapter *adapter = vport->adapter;
681 	int err;
682 
683 	if (is_valid_ether_addr(vport->default_mac_addr)) {
684 		eth_hw_addr_set(netdev, vport->default_mac_addr);
685 		ether_addr_copy(netdev->perm_addr, vport->default_mac_addr);
686 
687 		return idpf_add_mac_filter(vport, np, vport->default_mac_addr,
688 					   false);
689 	}
690 
691 	if (!idpf_is_cap_ena(adapter, IDPF_OTHER_CAPS,
692 			     VIRTCHNL2_CAP_MACFILTER)) {
693 		dev_err(&adapter->pdev->dev,
694 			"MAC address is not provided and capability is not set\n");
695 
696 		return -EINVAL;
697 	}
698 
699 	eth_hw_addr_random(netdev);
700 	err = idpf_add_mac_filter(vport, np, netdev->dev_addr, false);
701 	if (err)
702 		return err;
703 
704 	dev_info(&adapter->pdev->dev, "Invalid MAC address %pM, using random %pM\n",
705 		 vport->default_mac_addr, netdev->dev_addr);
706 	ether_addr_copy(vport->default_mac_addr, netdev->dev_addr);
707 
708 	return 0;
709 }
710 
711 /**
712  * idpf_cfg_netdev - Allocate, configure and register a netdev
713  * @vport: main vport structure
714  *
715  * Returns 0 on success, negative value on failure.
716  */
717 static int idpf_cfg_netdev(struct idpf_vport *vport)
718 {
719 	struct idpf_adapter *adapter = vport->adapter;
720 	struct idpf_vport_config *vport_config;
721 	netdev_features_t dflt_features;
722 	netdev_features_t offloads = 0;
723 	struct idpf_netdev_priv *np;
724 	struct net_device *netdev;
725 	u16 idx = vport->idx;
726 	int err;
727 
728 	vport_config = adapter->vport_config[idx];
729 
730 	/* It's possible we already have a netdev allocated and registered for
731 	 * this vport
732 	 */
733 	if (test_bit(IDPF_VPORT_REG_NETDEV, vport_config->flags)) {
734 		netdev = adapter->netdevs[idx];
735 		np = netdev_priv(netdev);
736 		np->vport = vport;
737 		np->vport_idx = vport->idx;
738 		np->vport_id = vport->vport_id;
739 		vport->netdev = netdev;
740 
741 		return idpf_init_mac_addr(vport, netdev);
742 	}
743 
744 	netdev = alloc_etherdev_mqs(sizeof(struct idpf_netdev_priv),
745 				    vport_config->max_q.max_txq,
746 				    vport_config->max_q.max_rxq);
747 	if (!netdev)
748 		return -ENOMEM;
749 
750 	vport->netdev = netdev;
751 	np = netdev_priv(netdev);
752 	np->vport = vport;
753 	np->adapter = adapter;
754 	np->vport_idx = vport->idx;
755 	np->vport_id = vport->vport_id;
756 
757 	spin_lock_init(&np->stats_lock);
758 
759 	err = idpf_init_mac_addr(vport, netdev);
760 	if (err) {
761 		free_netdev(vport->netdev);
762 		vport->netdev = NULL;
763 
764 		return err;
765 	}
766 
767 	/* assign netdev_ops */
768 	if (idpf_is_queue_model_split(vport->txq_model))
769 		netdev->netdev_ops = &idpf_netdev_ops_splitq;
770 	else
771 		netdev->netdev_ops = &idpf_netdev_ops_singleq;
772 
773 	/* setup watchdog timeout value to be 5 second */
774 	netdev->watchdog_timeo = 5 * HZ;
775 
776 	netdev->dev_port = idx;
777 
778 	/* configure default MTU size */
779 	netdev->min_mtu = ETH_MIN_MTU;
780 	netdev->max_mtu = vport->max_mtu;
781 
782 	dflt_features = NETIF_F_SG	|
783 			NETIF_F_HIGHDMA;
784 
785 	if (idpf_is_cap_ena_all(adapter, IDPF_RSS_CAPS, IDPF_CAP_RSS))
786 		dflt_features |= NETIF_F_RXHASH;
787 	if (idpf_is_cap_ena_all(adapter, IDPF_CSUM_CAPS, IDPF_CAP_RX_CSUM_L4V4))
788 		dflt_features |= NETIF_F_IP_CSUM;
789 	if (idpf_is_cap_ena_all(adapter, IDPF_CSUM_CAPS, IDPF_CAP_RX_CSUM_L4V6))
790 		dflt_features |= NETIF_F_IPV6_CSUM;
791 	if (idpf_is_cap_ena(adapter, IDPF_CSUM_CAPS, IDPF_CAP_RX_CSUM))
792 		dflt_features |= NETIF_F_RXCSUM;
793 	if (idpf_is_cap_ena_all(adapter, IDPF_CSUM_CAPS, IDPF_CAP_SCTP_CSUM))
794 		dflt_features |= NETIF_F_SCTP_CRC;
795 
796 	if (idpf_is_cap_ena(adapter, IDPF_SEG_CAPS, VIRTCHNL2_CAP_SEG_IPV4_TCP))
797 		dflt_features |= NETIF_F_TSO;
798 	if (idpf_is_cap_ena(adapter, IDPF_SEG_CAPS, VIRTCHNL2_CAP_SEG_IPV6_TCP))
799 		dflt_features |= NETIF_F_TSO6;
800 	if (idpf_is_cap_ena_all(adapter, IDPF_SEG_CAPS,
801 				VIRTCHNL2_CAP_SEG_IPV4_UDP |
802 				VIRTCHNL2_CAP_SEG_IPV6_UDP))
803 		dflt_features |= NETIF_F_GSO_UDP_L4;
804 	if (idpf_is_cap_ena_all(adapter, IDPF_RSC_CAPS, IDPF_CAP_RSC))
805 		offloads |= NETIF_F_GRO_HW;
806 	/* advertise to stack only if offloads for encapsulated packets is
807 	 * supported
808 	 */
809 	if (idpf_is_cap_ena(vport->adapter, IDPF_SEG_CAPS,
810 			    VIRTCHNL2_CAP_SEG_TX_SINGLE_TUNNEL)) {
811 		offloads |= NETIF_F_GSO_UDP_TUNNEL	|
812 			    NETIF_F_GSO_GRE		|
813 			    NETIF_F_GSO_GRE_CSUM	|
814 			    NETIF_F_GSO_PARTIAL		|
815 			    NETIF_F_GSO_UDP_TUNNEL_CSUM	|
816 			    NETIF_F_GSO_IPXIP4		|
817 			    NETIF_F_GSO_IPXIP6		|
818 			    0;
819 
820 		if (!idpf_is_cap_ena_all(vport->adapter, IDPF_CSUM_CAPS,
821 					 IDPF_CAP_TUNNEL_TX_CSUM))
822 			netdev->gso_partial_features |=
823 				NETIF_F_GSO_UDP_TUNNEL_CSUM;
824 
825 		netdev->gso_partial_features |= NETIF_F_GSO_GRE_CSUM;
826 		offloads |= NETIF_F_TSO_MANGLEID;
827 	}
828 	if (idpf_is_cap_ena(adapter, IDPF_OTHER_CAPS, VIRTCHNL2_CAP_LOOPBACK))
829 		offloads |= NETIF_F_LOOPBACK;
830 
831 	netdev->features |= dflt_features;
832 	netdev->hw_features |= dflt_features | offloads;
833 	netdev->hw_enc_features |= dflt_features | offloads;
834 	idpf_set_ethtool_ops(netdev);
835 	SET_NETDEV_DEV(netdev, &adapter->pdev->dev);
836 
837 	/* carrier off on init to avoid Tx hangs */
838 	netif_carrier_off(netdev);
839 
840 	/* make sure transmit queues start off as stopped */
841 	netif_tx_stop_all_queues(netdev);
842 
843 	/* The vport can be arbitrarily released so we need to also track
844 	 * netdevs in the adapter struct
845 	 */
846 	adapter->netdevs[idx] = netdev;
847 
848 	return 0;
849 }
850 
851 /**
852  * idpf_get_free_slot - get the next non-NULL location index in array
853  * @adapter: adapter in which to look for a free vport slot
854  */
855 static int idpf_get_free_slot(struct idpf_adapter *adapter)
856 {
857 	unsigned int i;
858 
859 	for (i = 0; i < adapter->max_vports; i++) {
860 		if (!adapter->vports[i])
861 			return i;
862 	}
863 
864 	return IDPF_NO_FREE_SLOT;
865 }
866 
867 /**
868  * idpf_remove_features - Turn off feature configs
869  * @vport: virtual port structure
870  */
871 static void idpf_remove_features(struct idpf_vport *vport)
872 {
873 	struct idpf_adapter *adapter = vport->adapter;
874 
875 	if (idpf_is_cap_ena(adapter, IDPF_OTHER_CAPS, VIRTCHNL2_CAP_MACFILTER))
876 		idpf_remove_mac_filters(vport);
877 }
878 
879 /**
880  * idpf_vport_stop - Disable a vport
881  * @vport: vport to disable
882  */
883 static void idpf_vport_stop(struct idpf_vport *vport)
884 {
885 	struct idpf_netdev_priv *np = netdev_priv(vport->netdev);
886 
887 	if (np->state <= __IDPF_VPORT_DOWN)
888 		return;
889 
890 	netif_carrier_off(vport->netdev);
891 	netif_tx_disable(vport->netdev);
892 
893 	idpf_send_disable_vport_msg(vport);
894 	idpf_send_disable_queues_msg(vport);
895 	idpf_send_map_unmap_queue_vector_msg(vport, false);
896 	/* Normally we ask for queues in create_vport, but if the number of
897 	 * initially requested queues have changed, for example via ethtool
898 	 * set channels, we do delete queues and then add the queues back
899 	 * instead of deleting and reallocating the vport.
900 	 */
901 	if (test_and_clear_bit(IDPF_VPORT_DEL_QUEUES, vport->flags))
902 		idpf_send_delete_queues_msg(vport);
903 
904 	idpf_remove_features(vport);
905 
906 	vport->link_up = false;
907 	idpf_vport_intr_deinit(vport);
908 	idpf_vport_intr_rel(vport);
909 	idpf_vport_queues_rel(vport);
910 	np->state = __IDPF_VPORT_DOWN;
911 }
912 
913 /**
914  * idpf_stop - Disables a network interface
915  * @netdev: network interface device structure
916  *
917  * The stop entry point is called when an interface is de-activated by the OS,
918  * and the netdevice enters the DOWN state.  The hardware is still under the
919  * driver's control, but the netdev interface is disabled.
920  *
921  * Returns success only - not allowed to fail
922  */
923 static int idpf_stop(struct net_device *netdev)
924 {
925 	struct idpf_netdev_priv *np = netdev_priv(netdev);
926 	struct idpf_vport *vport;
927 
928 	if (test_bit(IDPF_REMOVE_IN_PROG, np->adapter->flags))
929 		return 0;
930 
931 	idpf_vport_ctrl_lock(netdev);
932 	vport = idpf_netdev_to_vport(netdev);
933 
934 	idpf_vport_stop(vport);
935 
936 	idpf_vport_ctrl_unlock(netdev);
937 
938 	return 0;
939 }
940 
941 /**
942  * idpf_decfg_netdev - Unregister the netdev
943  * @vport: vport for which netdev to be unregistered
944  */
945 static void idpf_decfg_netdev(struct idpf_vport *vport)
946 {
947 	struct idpf_adapter *adapter = vport->adapter;
948 
949 	unregister_netdev(vport->netdev);
950 	free_netdev(vport->netdev);
951 	vport->netdev = NULL;
952 
953 	adapter->netdevs[vport->idx] = NULL;
954 }
955 
956 /**
957  * idpf_vport_rel - Delete a vport and free its resources
958  * @vport: the vport being removed
959  */
960 static void idpf_vport_rel(struct idpf_vport *vport)
961 {
962 	struct idpf_adapter *adapter = vport->adapter;
963 	struct idpf_vport_config *vport_config;
964 	struct idpf_vector_info vec_info;
965 	struct idpf_rss_data *rss_data;
966 	struct idpf_vport_max_q max_q;
967 	u16 idx = vport->idx;
968 
969 	vport_config = adapter->vport_config[vport->idx];
970 	idpf_deinit_rss(vport);
971 	rss_data = &vport_config->user_config.rss_data;
972 	kfree(rss_data->rss_key);
973 	rss_data->rss_key = NULL;
974 
975 	idpf_send_destroy_vport_msg(vport);
976 
977 	/* Release all max queues allocated to the adapter's pool */
978 	max_q.max_rxq = vport_config->max_q.max_rxq;
979 	max_q.max_txq = vport_config->max_q.max_txq;
980 	max_q.max_bufq = vport_config->max_q.max_bufq;
981 	max_q.max_complq = vport_config->max_q.max_complq;
982 	idpf_vport_dealloc_max_qs(adapter, &max_q);
983 
984 	/* Release all the allocated vectors on the stack */
985 	vec_info.num_req_vecs = 0;
986 	vec_info.num_curr_vecs = vport->num_q_vectors;
987 	vec_info.default_vport = vport->default_vport;
988 
989 	idpf_req_rel_vector_indexes(adapter, vport->q_vector_idxs, &vec_info);
990 
991 	kfree(vport->q_vector_idxs);
992 	vport->q_vector_idxs = NULL;
993 
994 	kfree(adapter->vport_params_recvd[idx]);
995 	adapter->vport_params_recvd[idx] = NULL;
996 	kfree(adapter->vport_params_reqd[idx]);
997 	adapter->vport_params_reqd[idx] = NULL;
998 	if (adapter->vport_config[idx]) {
999 		kfree(adapter->vport_config[idx]->req_qs_chunks);
1000 		adapter->vport_config[idx]->req_qs_chunks = NULL;
1001 	}
1002 	kfree(vport);
1003 	adapter->num_alloc_vports--;
1004 }
1005 
1006 /**
1007  * idpf_vport_dealloc - cleanup and release a given vport
1008  * @vport: pointer to idpf vport structure
1009  *
1010  * returns nothing
1011  */
1012 static void idpf_vport_dealloc(struct idpf_vport *vport)
1013 {
1014 	struct idpf_adapter *adapter = vport->adapter;
1015 	unsigned int i = vport->idx;
1016 
1017 	idpf_deinit_mac_addr(vport);
1018 	idpf_vport_stop(vport);
1019 
1020 	if (!test_bit(IDPF_HR_RESET_IN_PROG, adapter->flags))
1021 		idpf_decfg_netdev(vport);
1022 	if (test_bit(IDPF_REMOVE_IN_PROG, adapter->flags))
1023 		idpf_del_all_mac_filters(vport);
1024 
1025 	if (adapter->netdevs[i]) {
1026 		struct idpf_netdev_priv *np = netdev_priv(adapter->netdevs[i]);
1027 
1028 		np->vport = NULL;
1029 	}
1030 
1031 	idpf_vport_rel(vport);
1032 
1033 	adapter->vports[i] = NULL;
1034 	adapter->next_vport = idpf_get_free_slot(adapter);
1035 }
1036 
1037 /**
1038  * idpf_is_hsplit_supported - check whether the header split is supported
1039  * @vport: virtual port to check the capability for
1040  *
1041  * Return: true if it's supported by the HW/FW, false if not.
1042  */
1043 static bool idpf_is_hsplit_supported(const struct idpf_vport *vport)
1044 {
1045 	return idpf_is_queue_model_split(vport->rxq_model) &&
1046 	       idpf_is_cap_ena_all(vport->adapter, IDPF_HSPLIT_CAPS,
1047 				   IDPF_CAP_HSPLIT);
1048 }
1049 
1050 /**
1051  * idpf_vport_get_hsplit - get the current header split feature state
1052  * @vport: virtual port to query the state for
1053  *
1054  * Return: ``ETHTOOL_TCP_DATA_SPLIT_UNKNOWN`` if not supported,
1055  *         ``ETHTOOL_TCP_DATA_SPLIT_DISABLED`` if disabled,
1056  *         ``ETHTOOL_TCP_DATA_SPLIT_ENABLED`` if active.
1057  */
1058 u8 idpf_vport_get_hsplit(const struct idpf_vport *vport)
1059 {
1060 	const struct idpf_vport_user_config_data *config;
1061 
1062 	if (!idpf_is_hsplit_supported(vport))
1063 		return ETHTOOL_TCP_DATA_SPLIT_UNKNOWN;
1064 
1065 	config = &vport->adapter->vport_config[vport->idx]->user_config;
1066 
1067 	return test_bit(__IDPF_USER_FLAG_HSPLIT, config->user_flags) ?
1068 	       ETHTOOL_TCP_DATA_SPLIT_ENABLED :
1069 	       ETHTOOL_TCP_DATA_SPLIT_DISABLED;
1070 }
1071 
1072 /**
1073  * idpf_vport_set_hsplit - enable or disable header split on a given vport
1074  * @vport: virtual port to configure
1075  * @val: Ethtool flag controlling the header split state
1076  *
1077  * Return: true on success, false if not supported by the HW.
1078  */
1079 bool idpf_vport_set_hsplit(const struct idpf_vport *vport, u8 val)
1080 {
1081 	struct idpf_vport_user_config_data *config;
1082 
1083 	if (!idpf_is_hsplit_supported(vport))
1084 		return val == ETHTOOL_TCP_DATA_SPLIT_UNKNOWN;
1085 
1086 	config = &vport->adapter->vport_config[vport->idx]->user_config;
1087 
1088 	switch (val) {
1089 	case ETHTOOL_TCP_DATA_SPLIT_UNKNOWN:
1090 		/* Default is to enable */
1091 	case ETHTOOL_TCP_DATA_SPLIT_ENABLED:
1092 		__set_bit(__IDPF_USER_FLAG_HSPLIT, config->user_flags);
1093 		return true;
1094 	case ETHTOOL_TCP_DATA_SPLIT_DISABLED:
1095 		__clear_bit(__IDPF_USER_FLAG_HSPLIT, config->user_flags);
1096 		return true;
1097 	default:
1098 		return false;
1099 	}
1100 }
1101 
1102 /**
1103  * idpf_vport_alloc - Allocates the next available struct vport in the adapter
1104  * @adapter: board private structure
1105  * @max_q: vport max queue info
1106  *
1107  * returns a pointer to a vport on success, NULL on failure.
1108  */
1109 static struct idpf_vport *idpf_vport_alloc(struct idpf_adapter *adapter,
1110 					   struct idpf_vport_max_q *max_q)
1111 {
1112 	struct idpf_rss_data *rss_data;
1113 	u16 idx = adapter->next_vport;
1114 	struct idpf_vport *vport;
1115 	u16 num_max_q;
1116 
1117 	if (idx == IDPF_NO_FREE_SLOT)
1118 		return NULL;
1119 
1120 	vport = kzalloc(sizeof(*vport), GFP_KERNEL);
1121 	if (!vport)
1122 		return vport;
1123 
1124 	if (!adapter->vport_config[idx]) {
1125 		struct idpf_vport_config *vport_config;
1126 
1127 		vport_config = kzalloc(sizeof(*vport_config), GFP_KERNEL);
1128 		if (!vport_config) {
1129 			kfree(vport);
1130 
1131 			return NULL;
1132 		}
1133 
1134 		adapter->vport_config[idx] = vport_config;
1135 	}
1136 
1137 	vport->idx = idx;
1138 	vport->adapter = adapter;
1139 	vport->compln_clean_budget = IDPF_TX_COMPLQ_CLEAN_BUDGET;
1140 	vport->default_vport = adapter->num_alloc_vports <
1141 			       idpf_get_default_vports(adapter);
1142 
1143 	num_max_q = max(max_q->max_txq, max_q->max_rxq);
1144 	vport->q_vector_idxs = kcalloc(num_max_q, sizeof(u16), GFP_KERNEL);
1145 	if (!vport->q_vector_idxs) {
1146 		kfree(vport);
1147 
1148 		return NULL;
1149 	}
1150 	idpf_vport_init(vport, max_q);
1151 
1152 	/* This alloc is done separate from the LUT because it's not strictly
1153 	 * dependent on how many queues we have. If we change number of queues
1154 	 * and soft reset we'll need a new LUT but the key can remain the same
1155 	 * for as long as the vport exists.
1156 	 */
1157 	rss_data = &adapter->vport_config[idx]->user_config.rss_data;
1158 	rss_data->rss_key = kzalloc(rss_data->rss_key_size, GFP_KERNEL);
1159 	if (!rss_data->rss_key) {
1160 		kfree(vport);
1161 
1162 		return NULL;
1163 	}
1164 	/* Initialize default rss key */
1165 	netdev_rss_key_fill((void *)rss_data->rss_key, rss_data->rss_key_size);
1166 
1167 	/* fill vport slot in the adapter struct */
1168 	adapter->vports[idx] = vport;
1169 	adapter->vport_ids[idx] = idpf_get_vport_id(vport);
1170 
1171 	adapter->num_alloc_vports++;
1172 	/* prepare adapter->next_vport for next use */
1173 	adapter->next_vport = idpf_get_free_slot(adapter);
1174 
1175 	return vport;
1176 }
1177 
1178 /**
1179  * idpf_get_stats64 - get statistics for network device structure
1180  * @netdev: network interface device structure
1181  * @stats: main device statistics structure
1182  */
1183 static void idpf_get_stats64(struct net_device *netdev,
1184 			     struct rtnl_link_stats64 *stats)
1185 {
1186 	struct idpf_netdev_priv *np = netdev_priv(netdev);
1187 
1188 	spin_lock_bh(&np->stats_lock);
1189 	*stats = np->netstats;
1190 	spin_unlock_bh(&np->stats_lock);
1191 }
1192 
1193 /**
1194  * idpf_statistics_task - Delayed task to get statistics over mailbox
1195  * @work: work_struct handle to our data
1196  */
1197 void idpf_statistics_task(struct work_struct *work)
1198 {
1199 	struct idpf_adapter *adapter;
1200 	int i;
1201 
1202 	adapter = container_of(work, struct idpf_adapter, stats_task.work);
1203 
1204 	for (i = 0; i < adapter->max_vports; i++) {
1205 		struct idpf_vport *vport = adapter->vports[i];
1206 
1207 		if (vport && !test_bit(IDPF_HR_RESET_IN_PROG, adapter->flags))
1208 			idpf_send_get_stats_msg(vport);
1209 	}
1210 
1211 	queue_delayed_work(adapter->stats_wq, &adapter->stats_task,
1212 			   msecs_to_jiffies(10000));
1213 }
1214 
1215 /**
1216  * idpf_mbx_task - Delayed task to handle mailbox responses
1217  * @work: work_struct handle
1218  */
1219 void idpf_mbx_task(struct work_struct *work)
1220 {
1221 	struct idpf_adapter *adapter;
1222 
1223 	adapter = container_of(work, struct idpf_adapter, mbx_task.work);
1224 
1225 	if (test_bit(IDPF_MB_INTR_MODE, adapter->flags))
1226 		idpf_mb_irq_enable(adapter);
1227 	else
1228 		queue_delayed_work(adapter->mbx_wq, &adapter->mbx_task,
1229 				   msecs_to_jiffies(300));
1230 
1231 	idpf_recv_mb_msg(adapter);
1232 }
1233 
1234 /**
1235  * idpf_service_task - Delayed task for handling mailbox responses
1236  * @work: work_struct handle to our data
1237  *
1238  */
1239 void idpf_service_task(struct work_struct *work)
1240 {
1241 	struct idpf_adapter *adapter;
1242 
1243 	adapter = container_of(work, struct idpf_adapter, serv_task.work);
1244 
1245 	if (idpf_is_reset_detected(adapter) &&
1246 	    !idpf_is_reset_in_prog(adapter) &&
1247 	    !test_bit(IDPF_REMOVE_IN_PROG, adapter->flags)) {
1248 		dev_info(&adapter->pdev->dev, "HW reset detected\n");
1249 		set_bit(IDPF_HR_FUNC_RESET, adapter->flags);
1250 		queue_delayed_work(adapter->vc_event_wq,
1251 				   &adapter->vc_event_task,
1252 				   msecs_to_jiffies(10));
1253 	}
1254 
1255 	queue_delayed_work(adapter->serv_wq, &adapter->serv_task,
1256 			   msecs_to_jiffies(300));
1257 }
1258 
1259 /**
1260  * idpf_restore_features - Restore feature configs
1261  * @vport: virtual port structure
1262  */
1263 static void idpf_restore_features(struct idpf_vport *vport)
1264 {
1265 	struct idpf_adapter *adapter = vport->adapter;
1266 
1267 	if (idpf_is_cap_ena(adapter, IDPF_OTHER_CAPS, VIRTCHNL2_CAP_MACFILTER))
1268 		idpf_restore_mac_filters(vport);
1269 }
1270 
1271 /**
1272  * idpf_set_real_num_queues - set number of queues for netdev
1273  * @vport: virtual port structure
1274  *
1275  * Returns 0 on success, negative on failure.
1276  */
1277 static int idpf_set_real_num_queues(struct idpf_vport *vport)
1278 {
1279 	int err;
1280 
1281 	err = netif_set_real_num_rx_queues(vport->netdev, vport->num_rxq);
1282 	if (err)
1283 		return err;
1284 
1285 	return netif_set_real_num_tx_queues(vport->netdev, vport->num_txq);
1286 }
1287 
1288 /**
1289  * idpf_up_complete - Complete interface up sequence
1290  * @vport: virtual port structure
1291  *
1292  * Returns 0 on success, negative on failure.
1293  */
1294 static int idpf_up_complete(struct idpf_vport *vport)
1295 {
1296 	struct idpf_netdev_priv *np = netdev_priv(vport->netdev);
1297 
1298 	if (vport->link_up && !netif_carrier_ok(vport->netdev)) {
1299 		netif_carrier_on(vport->netdev);
1300 		netif_tx_start_all_queues(vport->netdev);
1301 	}
1302 
1303 	np->state = __IDPF_VPORT_UP;
1304 
1305 	return 0;
1306 }
1307 
1308 /**
1309  * idpf_rx_init_buf_tail - Write initial buffer ring tail value
1310  * @vport: virtual port struct
1311  */
1312 static void idpf_rx_init_buf_tail(struct idpf_vport *vport)
1313 {
1314 	int i, j;
1315 
1316 	for (i = 0; i < vport->num_rxq_grp; i++) {
1317 		struct idpf_rxq_group *grp = &vport->rxq_grps[i];
1318 
1319 		if (idpf_is_queue_model_split(vport->rxq_model)) {
1320 			for (j = 0; j < vport->num_bufqs_per_qgrp; j++) {
1321 				struct idpf_queue *q =
1322 					&grp->splitq.bufq_sets[j].bufq;
1323 
1324 				writel(q->next_to_alloc, q->tail);
1325 			}
1326 		} else {
1327 			for (j = 0; j < grp->singleq.num_rxq; j++) {
1328 				struct idpf_queue *q =
1329 					grp->singleq.rxqs[j];
1330 
1331 				writel(q->next_to_alloc, q->tail);
1332 			}
1333 		}
1334 	}
1335 }
1336 
1337 /**
1338  * idpf_vport_open - Bring up a vport
1339  * @vport: vport to bring up
1340  * @alloc_res: allocate queue resources
1341  */
1342 static int idpf_vport_open(struct idpf_vport *vport, bool alloc_res)
1343 {
1344 	struct idpf_netdev_priv *np = netdev_priv(vport->netdev);
1345 	struct idpf_adapter *adapter = vport->adapter;
1346 	struct idpf_vport_config *vport_config;
1347 	int err;
1348 
1349 	if (np->state != __IDPF_VPORT_DOWN)
1350 		return -EBUSY;
1351 
1352 	/* we do not allow interface up just yet */
1353 	netif_carrier_off(vport->netdev);
1354 
1355 	if (alloc_res) {
1356 		err = idpf_vport_queues_alloc(vport);
1357 		if (err)
1358 			return err;
1359 	}
1360 
1361 	err = idpf_vport_intr_alloc(vport);
1362 	if (err) {
1363 		dev_err(&adapter->pdev->dev, "Failed to allocate interrupts for vport %u: %d\n",
1364 			vport->vport_id, err);
1365 		goto queues_rel;
1366 	}
1367 
1368 	err = idpf_vport_queue_ids_init(vport);
1369 	if (err) {
1370 		dev_err(&adapter->pdev->dev, "Failed to initialize queue ids for vport %u: %d\n",
1371 			vport->vport_id, err);
1372 		goto intr_rel;
1373 	}
1374 
1375 	err = idpf_vport_intr_init(vport);
1376 	if (err) {
1377 		dev_err(&adapter->pdev->dev, "Failed to initialize interrupts for vport %u: %d\n",
1378 			vport->vport_id, err);
1379 		goto intr_rel;
1380 	}
1381 
1382 	err = idpf_rx_bufs_init_all(vport);
1383 	if (err) {
1384 		dev_err(&adapter->pdev->dev, "Failed to initialize RX buffers for vport %u: %d\n",
1385 			vport->vport_id, err);
1386 		goto intr_rel;
1387 	}
1388 
1389 	err = idpf_queue_reg_init(vport);
1390 	if (err) {
1391 		dev_err(&adapter->pdev->dev, "Failed to initialize queue registers for vport %u: %d\n",
1392 			vport->vport_id, err);
1393 		goto intr_rel;
1394 	}
1395 
1396 	idpf_rx_init_buf_tail(vport);
1397 	idpf_vport_intr_ena(vport);
1398 
1399 	err = idpf_send_config_queues_msg(vport);
1400 	if (err) {
1401 		dev_err(&adapter->pdev->dev, "Failed to configure queues for vport %u, %d\n",
1402 			vport->vport_id, err);
1403 		goto intr_deinit;
1404 	}
1405 
1406 	err = idpf_send_map_unmap_queue_vector_msg(vport, true);
1407 	if (err) {
1408 		dev_err(&adapter->pdev->dev, "Failed to map queue vectors for vport %u: %d\n",
1409 			vport->vport_id, err);
1410 		goto intr_deinit;
1411 	}
1412 
1413 	err = idpf_send_enable_queues_msg(vport);
1414 	if (err) {
1415 		dev_err(&adapter->pdev->dev, "Failed to enable queues for vport %u: %d\n",
1416 			vport->vport_id, err);
1417 		goto unmap_queue_vectors;
1418 	}
1419 
1420 	err = idpf_send_enable_vport_msg(vport);
1421 	if (err) {
1422 		dev_err(&adapter->pdev->dev, "Failed to enable vport %u: %d\n",
1423 			vport->vport_id, err);
1424 		err = -EAGAIN;
1425 		goto disable_queues;
1426 	}
1427 
1428 	idpf_restore_features(vport);
1429 
1430 	vport_config = adapter->vport_config[vport->idx];
1431 	if (vport_config->user_config.rss_data.rss_lut)
1432 		err = idpf_config_rss(vport);
1433 	else
1434 		err = idpf_init_rss(vport);
1435 	if (err) {
1436 		dev_err(&adapter->pdev->dev, "Failed to initialize RSS for vport %u: %d\n",
1437 			vport->vport_id, err);
1438 		goto disable_vport;
1439 	}
1440 
1441 	err = idpf_up_complete(vport);
1442 	if (err) {
1443 		dev_err(&adapter->pdev->dev, "Failed to complete interface up for vport %u: %d\n",
1444 			vport->vport_id, err);
1445 		goto deinit_rss;
1446 	}
1447 
1448 	return 0;
1449 
1450 deinit_rss:
1451 	idpf_deinit_rss(vport);
1452 disable_vport:
1453 	idpf_send_disable_vport_msg(vport);
1454 disable_queues:
1455 	idpf_send_disable_queues_msg(vport);
1456 unmap_queue_vectors:
1457 	idpf_send_map_unmap_queue_vector_msg(vport, false);
1458 intr_deinit:
1459 	idpf_vport_intr_deinit(vport);
1460 intr_rel:
1461 	idpf_vport_intr_rel(vport);
1462 queues_rel:
1463 	idpf_vport_queues_rel(vport);
1464 
1465 	return err;
1466 }
1467 
1468 /**
1469  * idpf_init_task - Delayed initialization task
1470  * @work: work_struct handle to our data
1471  *
1472  * Init task finishes up pending work started in probe. Due to the asynchronous
1473  * nature in which the device communicates with hardware, we may have to wait
1474  * several milliseconds to get a response.  Instead of busy polling in probe,
1475  * pulling it out into a delayed work task prevents us from bogging down the
1476  * whole system waiting for a response from hardware.
1477  */
1478 void idpf_init_task(struct work_struct *work)
1479 {
1480 	struct idpf_vport_config *vport_config;
1481 	struct idpf_vport_max_q max_q;
1482 	struct idpf_adapter *adapter;
1483 	struct idpf_netdev_priv *np;
1484 	struct idpf_vport *vport;
1485 	u16 num_default_vports;
1486 	struct pci_dev *pdev;
1487 	bool default_vport;
1488 	int index, err;
1489 
1490 	adapter = container_of(work, struct idpf_adapter, init_task.work);
1491 
1492 	num_default_vports = idpf_get_default_vports(adapter);
1493 	if (adapter->num_alloc_vports < num_default_vports)
1494 		default_vport = true;
1495 	else
1496 		default_vport = false;
1497 
1498 	err = idpf_vport_alloc_max_qs(adapter, &max_q);
1499 	if (err)
1500 		goto unwind_vports;
1501 
1502 	err = idpf_send_create_vport_msg(adapter, &max_q);
1503 	if (err) {
1504 		idpf_vport_dealloc_max_qs(adapter, &max_q);
1505 		goto unwind_vports;
1506 	}
1507 
1508 	pdev = adapter->pdev;
1509 	vport = idpf_vport_alloc(adapter, &max_q);
1510 	if (!vport) {
1511 		err = -EFAULT;
1512 		dev_err(&pdev->dev, "failed to allocate vport: %d\n",
1513 			err);
1514 		idpf_vport_dealloc_max_qs(adapter, &max_q);
1515 		goto unwind_vports;
1516 	}
1517 
1518 	index = vport->idx;
1519 	vport_config = adapter->vport_config[index];
1520 
1521 	init_waitqueue_head(&vport->sw_marker_wq);
1522 
1523 	spin_lock_init(&vport_config->mac_filter_list_lock);
1524 
1525 	INIT_LIST_HEAD(&vport_config->user_config.mac_filter_list);
1526 
1527 	err = idpf_check_supported_desc_ids(vport);
1528 	if (err) {
1529 		dev_err(&pdev->dev, "failed to get required descriptor ids\n");
1530 		goto cfg_netdev_err;
1531 	}
1532 
1533 	if (idpf_cfg_netdev(vport))
1534 		goto cfg_netdev_err;
1535 
1536 	err = idpf_send_get_rx_ptype_msg(vport);
1537 	if (err)
1538 		goto handle_err;
1539 
1540 	/* Once state is put into DOWN, driver is ready for dev_open */
1541 	np = netdev_priv(vport->netdev);
1542 	np->state = __IDPF_VPORT_DOWN;
1543 	if (test_and_clear_bit(IDPF_VPORT_UP_REQUESTED, vport_config->flags))
1544 		idpf_vport_open(vport, true);
1545 
1546 	/* Spawn and return 'idpf_init_task' work queue until all the
1547 	 * default vports are created
1548 	 */
1549 	if (adapter->num_alloc_vports < num_default_vports) {
1550 		queue_delayed_work(adapter->init_wq, &adapter->init_task,
1551 				   msecs_to_jiffies(5 * (adapter->pdev->devfn & 0x07)));
1552 
1553 		return;
1554 	}
1555 
1556 	for (index = 0; index < adapter->max_vports; index++) {
1557 		if (adapter->netdevs[index] &&
1558 		    !test_bit(IDPF_VPORT_REG_NETDEV,
1559 			      adapter->vport_config[index]->flags)) {
1560 			register_netdev(adapter->netdevs[index]);
1561 			set_bit(IDPF_VPORT_REG_NETDEV,
1562 				adapter->vport_config[index]->flags);
1563 		}
1564 	}
1565 
1566 	/* As all the required vports are created, clear the reset flag
1567 	 * unconditionally here in case we were in reset and the link was down.
1568 	 */
1569 	clear_bit(IDPF_HR_RESET_IN_PROG, adapter->flags);
1570 	/* Start the statistics task now */
1571 	queue_delayed_work(adapter->stats_wq, &adapter->stats_task,
1572 			   msecs_to_jiffies(10 * (pdev->devfn & 0x07)));
1573 
1574 	return;
1575 
1576 handle_err:
1577 	idpf_decfg_netdev(vport);
1578 cfg_netdev_err:
1579 	idpf_vport_rel(vport);
1580 	adapter->vports[index] = NULL;
1581 unwind_vports:
1582 	if (default_vport) {
1583 		for (index = 0; index < adapter->max_vports; index++) {
1584 			if (adapter->vports[index])
1585 				idpf_vport_dealloc(adapter->vports[index]);
1586 		}
1587 	}
1588 	clear_bit(IDPF_HR_RESET_IN_PROG, adapter->flags);
1589 }
1590 
1591 /**
1592  * idpf_sriov_ena - Enable or change number of VFs
1593  * @adapter: private data struct
1594  * @num_vfs: number of VFs to allocate
1595  */
1596 static int idpf_sriov_ena(struct idpf_adapter *adapter, int num_vfs)
1597 {
1598 	struct device *dev = &adapter->pdev->dev;
1599 	int err;
1600 
1601 	err = idpf_send_set_sriov_vfs_msg(adapter, num_vfs);
1602 	if (err) {
1603 		dev_err(dev, "Failed to allocate VFs: %d\n", err);
1604 
1605 		return err;
1606 	}
1607 
1608 	err = pci_enable_sriov(adapter->pdev, num_vfs);
1609 	if (err) {
1610 		idpf_send_set_sriov_vfs_msg(adapter, 0);
1611 		dev_err(dev, "Failed to enable SR-IOV: %d\n", err);
1612 
1613 		return err;
1614 	}
1615 
1616 	adapter->num_vfs = num_vfs;
1617 
1618 	return num_vfs;
1619 }
1620 
1621 /**
1622  * idpf_sriov_configure - Configure the requested VFs
1623  * @pdev: pointer to a pci_dev structure
1624  * @num_vfs: number of vfs to allocate
1625  *
1626  * Enable or change the number of VFs. Called when the user updates the number
1627  * of VFs in sysfs.
1628  **/
1629 int idpf_sriov_configure(struct pci_dev *pdev, int num_vfs)
1630 {
1631 	struct idpf_adapter *adapter = pci_get_drvdata(pdev);
1632 
1633 	if (!idpf_is_cap_ena(adapter, IDPF_OTHER_CAPS, VIRTCHNL2_CAP_SRIOV)) {
1634 		dev_info(&pdev->dev, "SR-IOV is not supported on this device\n");
1635 
1636 		return -EOPNOTSUPP;
1637 	}
1638 
1639 	if (num_vfs)
1640 		return idpf_sriov_ena(adapter, num_vfs);
1641 
1642 	if (pci_vfs_assigned(pdev)) {
1643 		dev_warn(&pdev->dev, "Unable to free VFs because some are assigned to VMs\n");
1644 
1645 		return -EBUSY;
1646 	}
1647 
1648 	pci_disable_sriov(adapter->pdev);
1649 	idpf_send_set_sriov_vfs_msg(adapter, 0);
1650 	adapter->num_vfs = 0;
1651 
1652 	return 0;
1653 }
1654 
1655 /**
1656  * idpf_deinit_task - Device deinit routine
1657  * @adapter: Driver specific private structure
1658  *
1659  * Extended remove logic which will be used for
1660  * hard reset as well
1661  */
1662 void idpf_deinit_task(struct idpf_adapter *adapter)
1663 {
1664 	unsigned int i;
1665 
1666 	/* Wait until the init_task is done else this thread might release
1667 	 * the resources first and the other thread might end up in a bad state
1668 	 */
1669 	cancel_delayed_work_sync(&adapter->init_task);
1670 
1671 	if (!adapter->vports)
1672 		return;
1673 
1674 	cancel_delayed_work_sync(&adapter->stats_task);
1675 
1676 	for (i = 0; i < adapter->max_vports; i++) {
1677 		if (adapter->vports[i])
1678 			idpf_vport_dealloc(adapter->vports[i]);
1679 	}
1680 }
1681 
1682 /**
1683  * idpf_check_reset_complete - check that reset is complete
1684  * @hw: pointer to hw struct
1685  * @reset_reg: struct with reset registers
1686  *
1687  * Returns 0 if device is ready to use, or -EBUSY if it's in reset.
1688  **/
1689 static int idpf_check_reset_complete(struct idpf_hw *hw,
1690 				     struct idpf_reset_reg *reset_reg)
1691 {
1692 	struct idpf_adapter *adapter = hw->back;
1693 	int i;
1694 
1695 	for (i = 0; i < 2000; i++) {
1696 		u32 reg_val = readl(reset_reg->rstat);
1697 
1698 		/* 0xFFFFFFFF might be read if other side hasn't cleared the
1699 		 * register for us yet and 0xFFFFFFFF is not a valid value for
1700 		 * the register, so treat that as invalid.
1701 		 */
1702 		if (reg_val != 0xFFFFFFFF && (reg_val & reset_reg->rstat_m))
1703 			return 0;
1704 
1705 		usleep_range(5000, 10000);
1706 	}
1707 
1708 	dev_warn(&adapter->pdev->dev, "Device reset timeout!\n");
1709 	/* Clear the reset flag unconditionally here since the reset
1710 	 * technically isn't in progress anymore from the driver's perspective
1711 	 */
1712 	clear_bit(IDPF_HR_RESET_IN_PROG, adapter->flags);
1713 
1714 	return -EBUSY;
1715 }
1716 
1717 /**
1718  * idpf_set_vport_state - Set the vport state to be after the reset
1719  * @adapter: Driver specific private structure
1720  */
1721 static void idpf_set_vport_state(struct idpf_adapter *adapter)
1722 {
1723 	u16 i;
1724 
1725 	for (i = 0; i < adapter->max_vports; i++) {
1726 		struct idpf_netdev_priv *np;
1727 
1728 		if (!adapter->netdevs[i])
1729 			continue;
1730 
1731 		np = netdev_priv(adapter->netdevs[i]);
1732 		if (np->state == __IDPF_VPORT_UP)
1733 			set_bit(IDPF_VPORT_UP_REQUESTED,
1734 				adapter->vport_config[i]->flags);
1735 	}
1736 }
1737 
1738 /**
1739  * idpf_init_hard_reset - Initiate a hardware reset
1740  * @adapter: Driver specific private structure
1741  *
1742  * Deallocate the vports and all the resources associated with them and
1743  * reallocate. Also reinitialize the mailbox. Return 0 on success,
1744  * negative on failure.
1745  */
1746 static int idpf_init_hard_reset(struct idpf_adapter *adapter)
1747 {
1748 	struct idpf_reg_ops *reg_ops = &adapter->dev_ops.reg_ops;
1749 	struct device *dev = &adapter->pdev->dev;
1750 	struct net_device *netdev;
1751 	int err;
1752 	u16 i;
1753 
1754 	mutex_lock(&adapter->vport_ctrl_lock);
1755 
1756 	dev_info(dev, "Device HW Reset initiated\n");
1757 
1758 	/* Avoid TX hangs on reset */
1759 	for (i = 0; i < adapter->max_vports; i++) {
1760 		netdev = adapter->netdevs[i];
1761 		if (!netdev)
1762 			continue;
1763 
1764 		netif_carrier_off(netdev);
1765 		netif_tx_disable(netdev);
1766 	}
1767 
1768 	/* Prepare for reset */
1769 	if (test_and_clear_bit(IDPF_HR_DRV_LOAD, adapter->flags)) {
1770 		reg_ops->trigger_reset(adapter, IDPF_HR_DRV_LOAD);
1771 	} else if (test_and_clear_bit(IDPF_HR_FUNC_RESET, adapter->flags)) {
1772 		bool is_reset = idpf_is_reset_detected(adapter);
1773 
1774 		idpf_set_vport_state(adapter);
1775 		idpf_vc_core_deinit(adapter);
1776 		if (!is_reset)
1777 			reg_ops->trigger_reset(adapter, IDPF_HR_FUNC_RESET);
1778 		idpf_deinit_dflt_mbx(adapter);
1779 	} else {
1780 		dev_err(dev, "Unhandled hard reset cause\n");
1781 		err = -EBADRQC;
1782 		goto unlock_mutex;
1783 	}
1784 
1785 	/* Wait for reset to complete */
1786 	err = idpf_check_reset_complete(&adapter->hw, &adapter->reset_reg);
1787 	if (err) {
1788 		dev_err(dev, "The driver was unable to contact the device's firmware. Check that the FW is running. Driver state= 0x%x\n",
1789 			adapter->state);
1790 		goto unlock_mutex;
1791 	}
1792 
1793 	/* Reset is complete and so start building the driver resources again */
1794 	err = idpf_init_dflt_mbx(adapter);
1795 	if (err) {
1796 		dev_err(dev, "Failed to initialize default mailbox: %d\n", err);
1797 		goto unlock_mutex;
1798 	}
1799 
1800 	queue_delayed_work(adapter->mbx_wq, &adapter->mbx_task, 0);
1801 
1802 	/* Initialize the state machine, also allocate memory and request
1803 	 * resources
1804 	 */
1805 	err = idpf_vc_core_init(adapter);
1806 	if (err) {
1807 		idpf_deinit_dflt_mbx(adapter);
1808 		goto unlock_mutex;
1809 	}
1810 
1811 	/* Wait till all the vports are initialized to release the reset lock,
1812 	 * else user space callbacks may access uninitialized vports
1813 	 */
1814 	while (test_bit(IDPF_HR_RESET_IN_PROG, adapter->flags))
1815 		msleep(100);
1816 
1817 unlock_mutex:
1818 	mutex_unlock(&adapter->vport_ctrl_lock);
1819 
1820 	return err;
1821 }
1822 
1823 /**
1824  * idpf_vc_event_task - Handle virtchannel event logic
1825  * @work: work queue struct
1826  */
1827 void idpf_vc_event_task(struct work_struct *work)
1828 {
1829 	struct idpf_adapter *adapter;
1830 
1831 	adapter = container_of(work, struct idpf_adapter, vc_event_task.work);
1832 
1833 	if (test_bit(IDPF_REMOVE_IN_PROG, adapter->flags))
1834 		return;
1835 
1836 	if (test_bit(IDPF_HR_FUNC_RESET, adapter->flags) ||
1837 	    test_bit(IDPF_HR_DRV_LOAD, adapter->flags)) {
1838 		set_bit(IDPF_HR_RESET_IN_PROG, adapter->flags);
1839 		idpf_init_hard_reset(adapter);
1840 	}
1841 }
1842 
1843 /**
1844  * idpf_initiate_soft_reset - Initiate a software reset
1845  * @vport: virtual port data struct
1846  * @reset_cause: reason for the soft reset
1847  *
1848  * Soft reset only reallocs vport queue resources. Returns 0 on success,
1849  * negative on failure.
1850  */
1851 int idpf_initiate_soft_reset(struct idpf_vport *vport,
1852 			     enum idpf_vport_reset_cause reset_cause)
1853 {
1854 	struct idpf_netdev_priv *np = netdev_priv(vport->netdev);
1855 	enum idpf_vport_state current_state = np->state;
1856 	struct idpf_adapter *adapter = vport->adapter;
1857 	struct idpf_vport *new_vport;
1858 	int err, i;
1859 
1860 	/* If the system is low on memory, we can end up in bad state if we
1861 	 * free all the memory for queue resources and try to allocate them
1862 	 * again. Instead, we can pre-allocate the new resources before doing
1863 	 * anything and bailing if the alloc fails.
1864 	 *
1865 	 * Make a clone of the existing vport to mimic its current
1866 	 * configuration, then modify the new structure with any requested
1867 	 * changes. Once the allocation of the new resources is done, stop the
1868 	 * existing vport and copy the configuration to the main vport. If an
1869 	 * error occurred, the existing vport will be untouched.
1870 	 *
1871 	 */
1872 	new_vport = kzalloc(sizeof(*vport), GFP_KERNEL);
1873 	if (!new_vport)
1874 		return -ENOMEM;
1875 
1876 	/* This purposely avoids copying the end of the struct because it
1877 	 * contains wait_queues and mutexes and other stuff we don't want to
1878 	 * mess with. Nothing below should use those variables from new_vport
1879 	 * and should instead always refer to them in vport if they need to.
1880 	 */
1881 	memcpy(new_vport, vport, offsetof(struct idpf_vport, link_speed_mbps));
1882 
1883 	/* Adjust resource parameters prior to reallocating resources */
1884 	switch (reset_cause) {
1885 	case IDPF_SR_Q_CHANGE:
1886 		err = idpf_vport_adjust_qs(new_vport);
1887 		if (err)
1888 			goto free_vport;
1889 		break;
1890 	case IDPF_SR_Q_DESC_CHANGE:
1891 		/* Update queue parameters before allocating resources */
1892 		idpf_vport_calc_num_q_desc(new_vport);
1893 		break;
1894 	case IDPF_SR_MTU_CHANGE:
1895 	case IDPF_SR_RSC_CHANGE:
1896 		break;
1897 	default:
1898 		dev_err(&adapter->pdev->dev, "Unhandled soft reset cause\n");
1899 		err = -EINVAL;
1900 		goto free_vport;
1901 	}
1902 
1903 	err = idpf_vport_queues_alloc(new_vport);
1904 	if (err)
1905 		goto free_vport;
1906 	if (current_state <= __IDPF_VPORT_DOWN) {
1907 		idpf_send_delete_queues_msg(vport);
1908 	} else {
1909 		set_bit(IDPF_VPORT_DEL_QUEUES, vport->flags);
1910 		idpf_vport_stop(vport);
1911 	}
1912 
1913 	idpf_deinit_rss(vport);
1914 	/* We're passing in vport here because we need its wait_queue
1915 	 * to send a message and it should be getting all the vport
1916 	 * config data out of the adapter but we need to be careful not
1917 	 * to add code to add_queues to change the vport config within
1918 	 * vport itself as it will be wiped with a memcpy later.
1919 	 */
1920 	err = idpf_send_add_queues_msg(vport, new_vport->num_txq,
1921 				       new_vport->num_complq,
1922 				       new_vport->num_rxq,
1923 				       new_vport->num_bufq);
1924 	if (err)
1925 		goto err_reset;
1926 
1927 	/* Same comment as above regarding avoiding copying the wait_queues and
1928 	 * mutexes applies here. We do not want to mess with those if possible.
1929 	 */
1930 	memcpy(vport, new_vport, offsetof(struct idpf_vport, link_speed_mbps));
1931 
1932 	/* Since idpf_vport_queues_alloc was called with new_port, the queue
1933 	 * back pointers are currently pointing to the local new_vport. Reset
1934 	 * the backpointers to the original vport here
1935 	 */
1936 	for (i = 0; i < vport->num_txq_grp; i++) {
1937 		struct idpf_txq_group *tx_qgrp = &vport->txq_grps[i];
1938 		int j;
1939 
1940 		tx_qgrp->vport = vport;
1941 		for (j = 0; j < tx_qgrp->num_txq; j++)
1942 			tx_qgrp->txqs[j]->vport = vport;
1943 
1944 		if (idpf_is_queue_model_split(vport->txq_model))
1945 			tx_qgrp->complq->vport = vport;
1946 	}
1947 
1948 	for (i = 0; i < vport->num_rxq_grp; i++) {
1949 		struct idpf_rxq_group *rx_qgrp = &vport->rxq_grps[i];
1950 		struct idpf_queue *q;
1951 		u16 num_rxq;
1952 		int j;
1953 
1954 		rx_qgrp->vport = vport;
1955 		for (j = 0; j < vport->num_bufqs_per_qgrp; j++)
1956 			rx_qgrp->splitq.bufq_sets[j].bufq.vport = vport;
1957 
1958 		if (idpf_is_queue_model_split(vport->rxq_model))
1959 			num_rxq = rx_qgrp->splitq.num_rxq_sets;
1960 		else
1961 			num_rxq = rx_qgrp->singleq.num_rxq;
1962 
1963 		for (j = 0; j < num_rxq; j++) {
1964 			if (idpf_is_queue_model_split(vport->rxq_model))
1965 				q = &rx_qgrp->splitq.rxq_sets[j]->rxq;
1966 			else
1967 				q = rx_qgrp->singleq.rxqs[j];
1968 			q->vport = vport;
1969 		}
1970 	}
1971 
1972 	if (reset_cause == IDPF_SR_Q_CHANGE)
1973 		idpf_vport_alloc_vec_indexes(vport);
1974 
1975 	err = idpf_set_real_num_queues(vport);
1976 	if (err)
1977 		goto err_reset;
1978 
1979 	if (current_state == __IDPF_VPORT_UP)
1980 		err = idpf_vport_open(vport, false);
1981 
1982 	kfree(new_vport);
1983 
1984 	return err;
1985 
1986 err_reset:
1987 	idpf_vport_queues_rel(new_vport);
1988 free_vport:
1989 	kfree(new_vport);
1990 
1991 	return err;
1992 }
1993 
1994 /**
1995  * idpf_addr_sync - Callback for dev_(mc|uc)_sync to add address
1996  * @netdev: the netdevice
1997  * @addr: address to add
1998  *
1999  * Called by __dev_(mc|uc)_sync when an address needs to be added. We call
2000  * __dev_(uc|mc)_sync from .set_rx_mode. Kernel takes addr_list_lock spinlock
2001  * meaning we cannot sleep in this context. Due to this, we have to add the
2002  * filter and send the virtchnl message asynchronously without waiting for the
2003  * response from the other side. We won't know whether or not the operation
2004  * actually succeeded until we get the message back.  Returns 0 on success,
2005  * negative on failure.
2006  */
2007 static int idpf_addr_sync(struct net_device *netdev, const u8 *addr)
2008 {
2009 	struct idpf_netdev_priv *np = netdev_priv(netdev);
2010 
2011 	return idpf_add_mac_filter(np->vport, np, addr, true);
2012 }
2013 
2014 /**
2015  * idpf_addr_unsync - Callback for dev_(mc|uc)_sync to remove address
2016  * @netdev: the netdevice
2017  * @addr: address to add
2018  *
2019  * Called by __dev_(mc|uc)_sync when an address needs to be added. We call
2020  * __dev_(uc|mc)_sync from .set_rx_mode. Kernel takes addr_list_lock spinlock
2021  * meaning we cannot sleep in this context. Due to this we have to delete the
2022  * filter and send the virtchnl message asynchronously without waiting for the
2023  * return from the other side.  We won't know whether or not the operation
2024  * actually succeeded until we get the message back. Returns 0 on success,
2025  * negative on failure.
2026  */
2027 static int idpf_addr_unsync(struct net_device *netdev, const u8 *addr)
2028 {
2029 	struct idpf_netdev_priv *np = netdev_priv(netdev);
2030 
2031 	/* Under some circumstances, we might receive a request to delete
2032 	 * our own device address from our uc list. Because we store the
2033 	 * device address in the VSI's MAC filter list, we need to ignore
2034 	 * such requests and not delete our device address from this list.
2035 	 */
2036 	if (ether_addr_equal(addr, netdev->dev_addr))
2037 		return 0;
2038 
2039 	idpf_del_mac_filter(np->vport, np, addr, true);
2040 
2041 	return 0;
2042 }
2043 
2044 /**
2045  * idpf_set_rx_mode - NDO callback to set the netdev filters
2046  * @netdev: network interface device structure
2047  *
2048  * Stack takes addr_list_lock spinlock before calling our .set_rx_mode.  We
2049  * cannot sleep in this context.
2050  */
2051 static void idpf_set_rx_mode(struct net_device *netdev)
2052 {
2053 	struct idpf_netdev_priv *np = netdev_priv(netdev);
2054 	struct idpf_vport_user_config_data *config_data;
2055 	struct idpf_adapter *adapter;
2056 	bool changed = false;
2057 	struct device *dev;
2058 	int err;
2059 
2060 	adapter = np->adapter;
2061 	dev = &adapter->pdev->dev;
2062 
2063 	if (idpf_is_cap_ena(adapter, IDPF_OTHER_CAPS, VIRTCHNL2_CAP_MACFILTER)) {
2064 		__dev_uc_sync(netdev, idpf_addr_sync, idpf_addr_unsync);
2065 		__dev_mc_sync(netdev, idpf_addr_sync, idpf_addr_unsync);
2066 	}
2067 
2068 	if (!idpf_is_cap_ena(adapter, IDPF_OTHER_CAPS, VIRTCHNL2_CAP_PROMISC))
2069 		return;
2070 
2071 	config_data = &adapter->vport_config[np->vport_idx]->user_config;
2072 	/* IFF_PROMISC enables both unicast and multicast promiscuous,
2073 	 * while IFF_ALLMULTI only enables multicast such that:
2074 	 *
2075 	 * promisc  + allmulti		= unicast | multicast
2076 	 * promisc  + !allmulti		= unicast | multicast
2077 	 * !promisc + allmulti		= multicast
2078 	 */
2079 	if ((netdev->flags & IFF_PROMISC) &&
2080 	    !test_and_set_bit(__IDPF_PROMISC_UC, config_data->user_flags)) {
2081 		changed = true;
2082 		dev_info(&adapter->pdev->dev, "Entering promiscuous mode\n");
2083 		if (!test_and_set_bit(__IDPF_PROMISC_MC, adapter->flags))
2084 			dev_info(dev, "Entering multicast promiscuous mode\n");
2085 	}
2086 
2087 	if (!(netdev->flags & IFF_PROMISC) &&
2088 	    test_and_clear_bit(__IDPF_PROMISC_UC, config_data->user_flags)) {
2089 		changed = true;
2090 		dev_info(dev, "Leaving promiscuous mode\n");
2091 	}
2092 
2093 	if (netdev->flags & IFF_ALLMULTI &&
2094 	    !test_and_set_bit(__IDPF_PROMISC_MC, config_data->user_flags)) {
2095 		changed = true;
2096 		dev_info(dev, "Entering multicast promiscuous mode\n");
2097 	}
2098 
2099 	if (!(netdev->flags & (IFF_ALLMULTI | IFF_PROMISC)) &&
2100 	    test_and_clear_bit(__IDPF_PROMISC_MC, config_data->user_flags)) {
2101 		changed = true;
2102 		dev_info(dev, "Leaving multicast promiscuous mode\n");
2103 	}
2104 
2105 	if (!changed)
2106 		return;
2107 
2108 	err = idpf_set_promiscuous(adapter, config_data, np->vport_id);
2109 	if (err)
2110 		dev_err(dev, "Failed to set promiscuous mode: %d\n", err);
2111 }
2112 
2113 /**
2114  * idpf_vport_manage_rss_lut - disable/enable RSS
2115  * @vport: the vport being changed
2116  *
2117  * In the event of disable request for RSS, this function will zero out RSS
2118  * LUT, while in the event of enable request for RSS, it will reconfigure RSS
2119  * LUT with the default LUT configuration.
2120  */
2121 static int idpf_vport_manage_rss_lut(struct idpf_vport *vport)
2122 {
2123 	bool ena = idpf_is_feature_ena(vport, NETIF_F_RXHASH);
2124 	struct idpf_rss_data *rss_data;
2125 	u16 idx = vport->idx;
2126 	int lut_size;
2127 
2128 	rss_data = &vport->adapter->vport_config[idx]->user_config.rss_data;
2129 	lut_size = rss_data->rss_lut_size * sizeof(u32);
2130 
2131 	if (ena) {
2132 		/* This will contain the default or user configured LUT */
2133 		memcpy(rss_data->rss_lut, rss_data->cached_lut, lut_size);
2134 	} else {
2135 		/* Save a copy of the current LUT to be restored later if
2136 		 * requested.
2137 		 */
2138 		memcpy(rss_data->cached_lut, rss_data->rss_lut, lut_size);
2139 
2140 		/* Zero out the current LUT to disable */
2141 		memset(rss_data->rss_lut, 0, lut_size);
2142 	}
2143 
2144 	return idpf_config_rss(vport);
2145 }
2146 
2147 /**
2148  * idpf_set_features - set the netdev feature flags
2149  * @netdev: ptr to the netdev being adjusted
2150  * @features: the feature set that the stack is suggesting
2151  */
2152 static int idpf_set_features(struct net_device *netdev,
2153 			     netdev_features_t features)
2154 {
2155 	netdev_features_t changed = netdev->features ^ features;
2156 	struct idpf_adapter *adapter;
2157 	struct idpf_vport *vport;
2158 	int err = 0;
2159 
2160 	idpf_vport_ctrl_lock(netdev);
2161 	vport = idpf_netdev_to_vport(netdev);
2162 
2163 	adapter = vport->adapter;
2164 
2165 	if (idpf_is_reset_in_prog(adapter)) {
2166 		dev_err(&adapter->pdev->dev, "Device is resetting, changing netdev features temporarily unavailable.\n");
2167 		err = -EBUSY;
2168 		goto unlock_mutex;
2169 	}
2170 
2171 	if (changed & NETIF_F_RXHASH) {
2172 		netdev->features ^= NETIF_F_RXHASH;
2173 		err = idpf_vport_manage_rss_lut(vport);
2174 		if (err)
2175 			goto unlock_mutex;
2176 	}
2177 
2178 	if (changed & NETIF_F_GRO_HW) {
2179 		netdev->features ^= NETIF_F_GRO_HW;
2180 		err = idpf_initiate_soft_reset(vport, IDPF_SR_RSC_CHANGE);
2181 		if (err)
2182 			goto unlock_mutex;
2183 	}
2184 
2185 	if (changed & NETIF_F_LOOPBACK) {
2186 		netdev->features ^= NETIF_F_LOOPBACK;
2187 		err = idpf_send_ena_dis_loopback_msg(vport);
2188 	}
2189 
2190 unlock_mutex:
2191 	idpf_vport_ctrl_unlock(netdev);
2192 
2193 	return err;
2194 }
2195 
2196 /**
2197  * idpf_open - Called when a network interface becomes active
2198  * @netdev: network interface device structure
2199  *
2200  * The open entry point is called when a network interface is made
2201  * active by the system (IFF_UP).  At this point all resources needed
2202  * for transmit and receive operations are allocated, the interrupt
2203  * handler is registered with the OS, the netdev watchdog is enabled,
2204  * and the stack is notified that the interface is ready.
2205  *
2206  * Returns 0 on success, negative value on failure
2207  */
2208 static int idpf_open(struct net_device *netdev)
2209 {
2210 	struct idpf_vport *vport;
2211 	int err;
2212 
2213 	idpf_vport_ctrl_lock(netdev);
2214 	vport = idpf_netdev_to_vport(netdev);
2215 
2216 	err = idpf_vport_open(vport, true);
2217 
2218 	idpf_vport_ctrl_unlock(netdev);
2219 
2220 	return err;
2221 }
2222 
2223 /**
2224  * idpf_change_mtu - NDO callback to change the MTU
2225  * @netdev: network interface device structure
2226  * @new_mtu: new value for maximum frame size
2227  *
2228  * Returns 0 on success, negative on failure
2229  */
2230 static int idpf_change_mtu(struct net_device *netdev, int new_mtu)
2231 {
2232 	struct idpf_vport *vport;
2233 	int err;
2234 
2235 	idpf_vport_ctrl_lock(netdev);
2236 	vport = idpf_netdev_to_vport(netdev);
2237 
2238 	WRITE_ONCE(netdev->mtu, new_mtu);
2239 
2240 	err = idpf_initiate_soft_reset(vport, IDPF_SR_MTU_CHANGE);
2241 
2242 	idpf_vport_ctrl_unlock(netdev);
2243 
2244 	return err;
2245 }
2246 
2247 /**
2248  * idpf_features_check - Validate packet conforms to limits
2249  * @skb: skb buffer
2250  * @netdev: This port's netdev
2251  * @features: Offload features that the stack believes apply
2252  */
2253 static netdev_features_t idpf_features_check(struct sk_buff *skb,
2254 					     struct net_device *netdev,
2255 					     netdev_features_t features)
2256 {
2257 	struct idpf_vport *vport = idpf_netdev_to_vport(netdev);
2258 	struct idpf_adapter *adapter = vport->adapter;
2259 	size_t len;
2260 
2261 	/* No point in doing any of this if neither checksum nor GSO are
2262 	 * being requested for this frame.  We can rule out both by just
2263 	 * checking for CHECKSUM_PARTIAL
2264 	 */
2265 	if (skb->ip_summed != CHECKSUM_PARTIAL)
2266 		return features;
2267 
2268 	/* We cannot support GSO if the MSS is going to be less than
2269 	 * 88 bytes. If it is then we need to drop support for GSO.
2270 	 */
2271 	if (skb_is_gso(skb) &&
2272 	    (skb_shinfo(skb)->gso_size < IDPF_TX_TSO_MIN_MSS))
2273 		features &= ~NETIF_F_GSO_MASK;
2274 
2275 	/* Ensure MACLEN is <= 126 bytes (63 words) and not an odd size */
2276 	len = skb_network_offset(skb);
2277 	if (unlikely(len & ~(126)))
2278 		goto unsupported;
2279 
2280 	len = skb_network_header_len(skb);
2281 	if (unlikely(len > idpf_get_max_tx_hdr_size(adapter)))
2282 		goto unsupported;
2283 
2284 	if (!skb->encapsulation)
2285 		return features;
2286 
2287 	/* L4TUNLEN can support 127 words */
2288 	len = skb_inner_network_header(skb) - skb_transport_header(skb);
2289 	if (unlikely(len & ~(127 * 2)))
2290 		goto unsupported;
2291 
2292 	/* IPLEN can support at most 127 dwords */
2293 	len = skb_inner_network_header_len(skb);
2294 	if (unlikely(len > idpf_get_max_tx_hdr_size(adapter)))
2295 		goto unsupported;
2296 
2297 	/* No need to validate L4LEN as TCP is the only protocol with a
2298 	 * a flexible value and we support all possible values supported
2299 	 * by TCP, which is at most 15 dwords
2300 	 */
2301 
2302 	return features;
2303 
2304 unsupported:
2305 	return features & ~(NETIF_F_CSUM_MASK | NETIF_F_GSO_MASK);
2306 }
2307 
2308 /**
2309  * idpf_set_mac - NDO callback to set port mac address
2310  * @netdev: network interface device structure
2311  * @p: pointer to an address structure
2312  *
2313  * Returns 0 on success, negative on failure
2314  **/
2315 static int idpf_set_mac(struct net_device *netdev, void *p)
2316 {
2317 	struct idpf_netdev_priv *np = netdev_priv(netdev);
2318 	struct idpf_vport_config *vport_config;
2319 	struct sockaddr *addr = p;
2320 	struct idpf_vport *vport;
2321 	int err = 0;
2322 
2323 	idpf_vport_ctrl_lock(netdev);
2324 	vport = idpf_netdev_to_vport(netdev);
2325 
2326 	if (!idpf_is_cap_ena(vport->adapter, IDPF_OTHER_CAPS,
2327 			     VIRTCHNL2_CAP_MACFILTER)) {
2328 		dev_info(&vport->adapter->pdev->dev, "Setting MAC address is not supported\n");
2329 		err = -EOPNOTSUPP;
2330 		goto unlock_mutex;
2331 	}
2332 
2333 	if (!is_valid_ether_addr(addr->sa_data)) {
2334 		dev_info(&vport->adapter->pdev->dev, "Invalid MAC address: %pM\n",
2335 			 addr->sa_data);
2336 		err = -EADDRNOTAVAIL;
2337 		goto unlock_mutex;
2338 	}
2339 
2340 	if (ether_addr_equal(netdev->dev_addr, addr->sa_data))
2341 		goto unlock_mutex;
2342 
2343 	vport_config = vport->adapter->vport_config[vport->idx];
2344 	err = idpf_add_mac_filter(vport, np, addr->sa_data, false);
2345 	if (err) {
2346 		__idpf_del_mac_filter(vport_config, addr->sa_data);
2347 		goto unlock_mutex;
2348 	}
2349 
2350 	if (is_valid_ether_addr(vport->default_mac_addr))
2351 		idpf_del_mac_filter(vport, np, vport->default_mac_addr, false);
2352 
2353 	ether_addr_copy(vport->default_mac_addr, addr->sa_data);
2354 	eth_hw_addr_set(netdev, addr->sa_data);
2355 
2356 unlock_mutex:
2357 	idpf_vport_ctrl_unlock(netdev);
2358 
2359 	return err;
2360 }
2361 
2362 /**
2363  * idpf_alloc_dma_mem - Allocate dma memory
2364  * @hw: pointer to hw struct
2365  * @mem: pointer to dma_mem struct
2366  * @size: size of the memory to allocate
2367  */
2368 void *idpf_alloc_dma_mem(struct idpf_hw *hw, struct idpf_dma_mem *mem, u64 size)
2369 {
2370 	struct idpf_adapter *adapter = hw->back;
2371 	size_t sz = ALIGN(size, 4096);
2372 
2373 	mem->va = dma_alloc_coherent(&adapter->pdev->dev, sz,
2374 				     &mem->pa, GFP_KERNEL);
2375 	mem->size = sz;
2376 
2377 	return mem->va;
2378 }
2379 
2380 /**
2381  * idpf_free_dma_mem - Free the allocated dma memory
2382  * @hw: pointer to hw struct
2383  * @mem: pointer to dma_mem struct
2384  */
2385 void idpf_free_dma_mem(struct idpf_hw *hw, struct idpf_dma_mem *mem)
2386 {
2387 	struct idpf_adapter *adapter = hw->back;
2388 
2389 	dma_free_coherent(&adapter->pdev->dev, mem->size,
2390 			  mem->va, mem->pa);
2391 	mem->size = 0;
2392 	mem->va = NULL;
2393 	mem->pa = 0;
2394 }
2395 
2396 static const struct net_device_ops idpf_netdev_ops_splitq = {
2397 	.ndo_open = idpf_open,
2398 	.ndo_stop = idpf_stop,
2399 	.ndo_start_xmit = idpf_tx_splitq_start,
2400 	.ndo_features_check = idpf_features_check,
2401 	.ndo_set_rx_mode = idpf_set_rx_mode,
2402 	.ndo_validate_addr = eth_validate_addr,
2403 	.ndo_set_mac_address = idpf_set_mac,
2404 	.ndo_change_mtu = idpf_change_mtu,
2405 	.ndo_get_stats64 = idpf_get_stats64,
2406 	.ndo_set_features = idpf_set_features,
2407 	.ndo_tx_timeout = idpf_tx_timeout,
2408 };
2409 
2410 static const struct net_device_ops idpf_netdev_ops_singleq = {
2411 	.ndo_open = idpf_open,
2412 	.ndo_stop = idpf_stop,
2413 	.ndo_start_xmit = idpf_tx_singleq_start,
2414 	.ndo_features_check = idpf_features_check,
2415 	.ndo_set_rx_mode = idpf_set_rx_mode,
2416 	.ndo_validate_addr = eth_validate_addr,
2417 	.ndo_set_mac_address = idpf_set_mac,
2418 	.ndo_change_mtu = idpf_change_mtu,
2419 	.ndo_get_stats64 = idpf_get_stats64,
2420 	.ndo_set_features = idpf_set_features,
2421 	.ndo_tx_timeout = idpf_tx_timeout,
2422 };
2423