xref: /freebsd/sys/dev/ixgbe/if_ixv.c (revision 78b9f0095b4af3aca6c931b2c7b009ddb8a05125)
1 /******************************************************************************
2 
3   Copyright (c) 2001-2017, Intel Corporation
4   All rights reserved.
5 
6   Redistribution and use in source and binary forms, with or without
7   modification, are permitted provided that the following conditions are met:
8 
9    1. Redistributions of source code must retain the above copyright notice,
10       this list of conditions and the following disclaimer.
11 
12    2. Redistributions in binary form must reproduce the above copyright
13       notice, this list of conditions and the following disclaimer in the
14       documentation and/or other materials provided with the distribution.
15 
16    3. Neither the name of the Intel Corporation nor the names of its
17       contributors may be used to endorse or promote products derived from
18       this software without specific prior written permission.
19 
20   THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
21   AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22   IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
23   ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
24   LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
25   CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
26   SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
27   INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
28   CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
29   ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
30   POSSIBILITY OF SUCH DAMAGE.
31 
32 ******************************************************************************/
33 /*$FreeBSD$*/
34 
35 
36 #include "opt_inet.h"
37 #include "opt_inet6.h"
38 
39 #include "ixgbe.h"
40 #include "ifdi_if.h"
41 
42 #include <net/netmap.h>
43 #include <dev/netmap/netmap_kern.h>
44 
45 /************************************************************************
46  * Driver version
47  ************************************************************************/
48 char ixv_driver_version[] = "2.0.1-k";
49 
50 /************************************************************************
51  * PCI Device ID Table
52  *
53  *   Used by probe to select devices to load on
54  *   Last field stores an index into ixv_strings
55  *   Last entry must be all 0s
56  *
57  *   { Vendor ID, Device ID, SubVendor ID, SubDevice ID, String Index }
58  ************************************************************************/
59 static pci_vendor_info_t ixv_vendor_info_array[] =
60 {
61 	PVID(IXGBE_INTEL_VENDOR_ID, IXGBE_DEV_ID_82599_VF, "Intel(R) PRO/10GbE Virtual Function Network Driver"),
62 	PVID(IXGBE_INTEL_VENDOR_ID, IXGBE_DEV_ID_X540_VF, "Intel(R) PRO/10GbE Virtual Function Network Driver"),
63 	PVID(IXGBE_INTEL_VENDOR_ID, IXGBE_DEV_ID_X550_VF, "Intel(R) PRO/10GbE Virtual Function Network Driver"),
64 	PVID(IXGBE_INTEL_VENDOR_ID, IXGBE_DEV_ID_X550EM_X_VF, "Intel(R) PRO/10GbE Virtual Function Network Driver"),
65 	PVID(IXGBE_INTEL_VENDOR_ID, IXGBE_DEV_ID_X550EM_A_VF, "Intel(R) PRO/10GbE Virtual Function Network Driver"),
66 	/* required last entry */
67 PVID_END
68 };
69 
70 /************************************************************************
71  * Function prototypes
72  ************************************************************************/
73 static void     *ixv_register(device_t dev);
74 static int      ixv_if_attach_pre(if_ctx_t ctx);
75 static int      ixv_if_attach_post(if_ctx_t ctx);
76 static int      ixv_if_detach(if_ctx_t ctx);
77 
78 static int      ixv_if_rx_queue_intr_enable(if_ctx_t ctx, uint16_t qid);
79 static int      ixv_if_tx_queues_alloc(if_ctx_t ctx, caddr_t *vaddrs, uint64_t *paddrs, int nqs, int nqsets);
80 static int      ixv_if_rx_queues_alloc(if_ctx_t ctx, caddr_t *vaddrs, uint64_t *paddrs, int nqs, int nqsets);
81 static void     ixv_if_queues_free(if_ctx_t ctx);
82 static void     ixv_identify_hardware(if_ctx_t ctx);
83 static void     ixv_init_device_features(struct adapter *);
84 static int      ixv_allocate_pci_resources(if_ctx_t ctx);
85 static void     ixv_free_pci_resources(if_ctx_t ctx);
86 static int      ixv_setup_interface(if_ctx_t ctx);
87 static void     ixv_if_media_status(if_ctx_t , struct ifmediareq *);
88 static int      ixv_if_media_change(if_ctx_t ctx);
89 static void     ixv_if_update_admin_status(if_ctx_t ctx);
90 static int      ixv_if_msix_intr_assign(if_ctx_t ctx, int msix);
91 
92 static int      ixv_if_mtu_set(if_ctx_t ctx, uint32_t mtu);
93 static void     ixv_if_init(if_ctx_t ctx);
94 static void     ixv_if_local_timer(if_ctx_t ctx, uint16_t qid);
95 static void     ixv_if_stop(if_ctx_t ctx);
96 static int      ixv_negotiate_api(struct adapter *);
97 
98 static void     ixv_initialize_transmit_units(if_ctx_t ctx);
99 static void     ixv_initialize_receive_units(if_ctx_t ctx);
100 static void     ixv_initialize_rss_mapping(struct adapter *);
101 
102 static void     ixv_setup_vlan_support(if_ctx_t ctx);
103 static void     ixv_configure_ivars(struct adapter *);
104 static void     ixv_if_enable_intr(if_ctx_t ctx);
105 static void     ixv_if_disable_intr(if_ctx_t ctx);
106 static void     ixv_if_multi_set(if_ctx_t ctx);
107 
108 static void     ixv_if_register_vlan(if_ctx_t, u16);
109 static void     ixv_if_unregister_vlan(if_ctx_t, u16);
110 
111 static uint64_t ixv_if_get_counter(if_ctx_t, ift_counter);
112 
113 static void     ixv_save_stats(struct adapter *);
114 static void     ixv_init_stats(struct adapter *);
115 static void     ixv_update_stats(struct adapter *);
116 static void     ixv_add_stats_sysctls(struct adapter *adapter);
117 
118 static int      ixv_sysctl_debug(SYSCTL_HANDLER_ARGS);
119 static void     ixv_set_ivar(struct adapter *, u8, u8, s8);
120 
121 static u8       *ixv_mc_array_itr(struct ixgbe_hw *, u8 **, u32 *);
122 
123 /* The MSI-X Interrupt handlers */
124 static int      ixv_msix_que(void *);
125 static int      ixv_msix_mbx(void *);
126 
127 /************************************************************************
128  * FreeBSD Device Interface Entry Points
129  ************************************************************************/
130 static device_method_t ixv_methods[] = {
131 	/* Device interface */
132 	DEVMETHOD(device_register, ixv_register),
133 	DEVMETHOD(device_probe, iflib_device_probe),
134 	DEVMETHOD(device_attach, iflib_device_attach),
135 	DEVMETHOD(device_detach, iflib_device_detach),
136 	DEVMETHOD(device_shutdown, iflib_device_shutdown),
137 	DEVMETHOD_END
138 };
139 
140 static driver_t ixv_driver = {
141 	"ixv", ixv_methods, sizeof(struct adapter),
142 };
143 
144 devclass_t ixv_devclass;
145 DRIVER_MODULE(ixv, pci, ixv_driver, ixv_devclass, 0, 0);
146 MODULE_PNP_INFO("U16:vendor;U16:device", pci, ixv, ixv_vendor_info_array,
147     sizeof(ixv_vendor_info_array[0]), nitems(ixv_vendor_info_array) - 1);
148 MODULE_DEPEND(ixv, pci, 1, 1, 1);
149 MODULE_DEPEND(ixv, ether, 1, 1, 1);
150 #ifdef DEV_NETMAP
151 MODULE_DEPEND(ixv, netmap, 1, 1, 1);
152 #endif /* DEV_NETMAP */
153 
154 static device_method_t ixv_if_methods[] = {
155 	DEVMETHOD(ifdi_attach_pre, ixv_if_attach_pre),
156 	DEVMETHOD(ifdi_attach_post, ixv_if_attach_post),
157 	DEVMETHOD(ifdi_detach, ixv_if_detach),
158 	DEVMETHOD(ifdi_init, ixv_if_init),
159 	DEVMETHOD(ifdi_stop, ixv_if_stop),
160 	DEVMETHOD(ifdi_msix_intr_assign, ixv_if_msix_intr_assign),
161 	DEVMETHOD(ifdi_intr_enable, ixv_if_enable_intr),
162 	DEVMETHOD(ifdi_intr_disable, ixv_if_disable_intr),
163 	DEVMETHOD(ifdi_tx_queue_intr_enable, ixv_if_rx_queue_intr_enable),
164 	DEVMETHOD(ifdi_rx_queue_intr_enable, ixv_if_rx_queue_intr_enable),
165 	DEVMETHOD(ifdi_tx_queues_alloc, ixv_if_tx_queues_alloc),
166 	DEVMETHOD(ifdi_rx_queues_alloc, ixv_if_rx_queues_alloc),
167 	DEVMETHOD(ifdi_queues_free, ixv_if_queues_free),
168 	DEVMETHOD(ifdi_update_admin_status, ixv_if_update_admin_status),
169 	DEVMETHOD(ifdi_multi_set, ixv_if_multi_set),
170 	DEVMETHOD(ifdi_mtu_set, ixv_if_mtu_set),
171 	DEVMETHOD(ifdi_media_status, ixv_if_media_status),
172 	DEVMETHOD(ifdi_media_change, ixv_if_media_change),
173 	DEVMETHOD(ifdi_timer, ixv_if_local_timer),
174 	DEVMETHOD(ifdi_vlan_register, ixv_if_register_vlan),
175 	DEVMETHOD(ifdi_vlan_unregister, ixv_if_unregister_vlan),
176 	DEVMETHOD(ifdi_get_counter, ixv_if_get_counter),
177 	DEVMETHOD_END
178 };
179 
180 static driver_t ixv_if_driver = {
181   "ixv_if", ixv_if_methods, sizeof(struct adapter)
182 };
183 
184 /*
185  * TUNEABLE PARAMETERS:
186  */
187 
188 /* Flow control setting, default to full */
189 static int ixv_flow_control = ixgbe_fc_full;
190 TUNABLE_INT("hw.ixv.flow_control", &ixv_flow_control);
191 
192 /*
193  * Header split: this causes the hardware to DMA
194  * the header into a separate mbuf from the payload,
195  * it can be a performance win in some workloads, but
196  * in others it actually hurts, its off by default.
197  */
198 static int ixv_header_split = FALSE;
199 TUNABLE_INT("hw.ixv.hdr_split", &ixv_header_split);
200 
201 /*
202  * Shadow VFTA table, this is needed because
203  * the real filter table gets cleared during
204  * a soft reset and we need to repopulate it.
205  */
206 static u32 ixv_shadow_vfta[IXGBE_VFTA_SIZE];
207 extern struct if_txrx ixgbe_txrx;
208 
209 static struct if_shared_ctx ixv_sctx_init = {
210 	.isc_magic = IFLIB_MAGIC,
211 	.isc_q_align = PAGE_SIZE,/* max(DBA_ALIGN, PAGE_SIZE) */
212 	.isc_tx_maxsize = IXGBE_TSO_SIZE + sizeof(struct ether_vlan_header),
213 	.isc_tx_maxsegsize = PAGE_SIZE,
214 	.isc_tso_maxsize = IXGBE_TSO_SIZE + sizeof(struct ether_vlan_header),
215 	.isc_tso_maxsegsize = PAGE_SIZE,
216 	.isc_rx_maxsize = MJUM16BYTES,
217 	.isc_rx_nsegments = 1,
218 	.isc_rx_maxsegsize = MJUM16BYTES,
219 	.isc_nfl = 1,
220 	.isc_ntxqs = 1,
221 	.isc_nrxqs = 1,
222 	.isc_admin_intrcnt = 1,
223 	.isc_vendor_info = ixv_vendor_info_array,
224 	.isc_driver_version = ixv_driver_version,
225 	.isc_driver = &ixv_if_driver,
226 
227 	.isc_nrxd_min = {MIN_RXD},
228 	.isc_ntxd_min = {MIN_TXD},
229 	.isc_nrxd_max = {MAX_RXD},
230 	.isc_ntxd_max = {MAX_TXD},
231 	.isc_nrxd_default = {DEFAULT_RXD},
232 	.isc_ntxd_default = {DEFAULT_TXD},
233 };
234 
235 if_shared_ctx_t ixv_sctx = &ixv_sctx_init;
236 
237 static void *
238 ixv_register(device_t dev)
239 {
240 	return (ixv_sctx);
241 }
242 
243 /************************************************************************
244  * ixv_if_tx_queues_alloc
245  ************************************************************************/
246 static int
247 ixv_if_tx_queues_alloc(if_ctx_t ctx, caddr_t *vaddrs, uint64_t *paddrs,
248                        int ntxqs, int ntxqsets)
249 {
250 	struct adapter     *adapter = iflib_get_softc(ctx);
251 	if_softc_ctx_t     scctx = adapter->shared;
252 	struct ix_tx_queue *que;
253 	int                i, j, error;
254 
255 	MPASS(adapter->num_tx_queues == ntxqsets);
256 	MPASS(ntxqs == 1);
257 
258 	/* Allocate queue structure memory */
259 	adapter->tx_queues =
260 	    (struct ix_tx_queue *)malloc(sizeof(struct ix_tx_queue) * ntxqsets,
261 	                                 M_DEVBUF, M_NOWAIT | M_ZERO);
262 	if (!adapter->tx_queues) {
263 		device_printf(iflib_get_dev(ctx),
264 		    "Unable to allocate TX ring memory\n");
265 		return (ENOMEM);
266 	}
267 
268 	for (i = 0, que = adapter->tx_queues; i < ntxqsets; i++, que++) {
269 		struct tx_ring *txr = &que->txr;
270 
271 		txr->me = i;
272 		txr->adapter =  que->adapter = adapter;
273 		adapter->active_queues |= (u64)1 << txr->me;
274 
275 		/* Allocate report status array */
276 		if (!(txr->tx_rsq = (qidx_t *)malloc(sizeof(qidx_t) * scctx->isc_ntxd[0], M_DEVBUF, M_NOWAIT | M_ZERO))) {
277 			error = ENOMEM;
278 			goto fail;
279 		}
280 		for (j = 0; j < scctx->isc_ntxd[0]; j++)
281 			txr->tx_rsq[j] = QIDX_INVALID;
282 		/* get the virtual and physical address of the hardware queues */
283 		txr->tail = IXGBE_VFTDT(txr->me);
284 		txr->tx_base = (union ixgbe_adv_tx_desc *)vaddrs[i*ntxqs];
285 		txr->tx_paddr = paddrs[i*ntxqs];
286 
287 		txr->bytes = 0;
288 		txr->total_packets = 0;
289 
290 	}
291 
292 	device_printf(iflib_get_dev(ctx), "allocated for %d queues\n",
293 	    adapter->num_tx_queues);
294 
295 	return (0);
296 
297  fail:
298 	ixv_if_queues_free(ctx);
299 
300 	return (error);
301 } /* ixv_if_tx_queues_alloc */
302 
303 /************************************************************************
304  * ixv_if_rx_queues_alloc
305  ************************************************************************/
306 static int
307 ixv_if_rx_queues_alloc(if_ctx_t ctx, caddr_t *vaddrs, uint64_t *paddrs,
308                        int nrxqs, int nrxqsets)
309 {
310 	struct adapter     *adapter = iflib_get_softc(ctx);
311 	struct ix_rx_queue *que;
312 	int                i, error;
313 
314 	MPASS(adapter->num_rx_queues == nrxqsets);
315 	MPASS(nrxqs == 1);
316 
317 	/* Allocate queue structure memory */
318 	adapter->rx_queues =
319 	    (struct ix_rx_queue *)malloc(sizeof(struct ix_rx_queue) * nrxqsets,
320 	                                 M_DEVBUF, M_NOWAIT | M_ZERO);
321 	if (!adapter->rx_queues) {
322 		device_printf(iflib_get_dev(ctx),
323 		    "Unable to allocate TX ring memory\n");
324 		error = ENOMEM;
325 		goto fail;
326 	}
327 
328 	for (i = 0, que = adapter->rx_queues; i < nrxqsets; i++, que++) {
329 		struct rx_ring *rxr = &que->rxr;
330 		rxr->me = i;
331 		rxr->adapter = que->adapter = adapter;
332 
333 
334 		/* get the virtual and physical address of the hw queues */
335 		rxr->tail = IXGBE_VFRDT(rxr->me);
336 		rxr->rx_base = (union ixgbe_adv_rx_desc *)vaddrs[i];
337 		rxr->rx_paddr = paddrs[i*nrxqs];
338 		rxr->bytes = 0;
339 		rxr->que = que;
340 	}
341 
342 	device_printf(iflib_get_dev(ctx), "allocated for %d rx queues\n",
343 	    adapter->num_rx_queues);
344 
345 	return (0);
346 
347 fail:
348 	ixv_if_queues_free(ctx);
349 
350 	return (error);
351 } /* ixv_if_rx_queues_alloc */
352 
353 /************************************************************************
354  * ixv_if_queues_free
355  ************************************************************************/
356 static void
357 ixv_if_queues_free(if_ctx_t ctx)
358 {
359 	struct adapter     *adapter = iflib_get_softc(ctx);
360 	struct ix_tx_queue *que = adapter->tx_queues;
361 	int                i;
362 
363 	if (que == NULL)
364 		goto free;
365 
366 	for (i = 0; i < adapter->num_tx_queues; i++, que++) {
367 		struct tx_ring *txr = &que->txr;
368 		if (txr->tx_rsq == NULL)
369 			break;
370 
371 		free(txr->tx_rsq, M_DEVBUF);
372 		txr->tx_rsq = NULL;
373 	}
374 	if (adapter->tx_queues != NULL)
375 		free(adapter->tx_queues, M_DEVBUF);
376 free:
377 	if (adapter->rx_queues != NULL)
378 		free(adapter->rx_queues, M_DEVBUF);
379 	adapter->tx_queues = NULL;
380 	adapter->rx_queues = NULL;
381 } /* ixv_if_queues_free */
382 
383 /************************************************************************
384  * ixv_if_attach_pre - Device initialization routine
385  *
386  *   Called when the driver is being loaded.
387  *   Identifies the type of hardware, allocates all resources
388  *   and initializes the hardware.
389  *
390  *   return 0 on success, positive on failure
391  ************************************************************************/
392 static int
393 ixv_if_attach_pre(if_ctx_t ctx)
394 {
395 	struct adapter  *adapter;
396 	device_t        dev;
397 	if_softc_ctx_t  scctx;
398 	struct ixgbe_hw *hw;
399 	int             error = 0;
400 
401 	INIT_DEBUGOUT("ixv_attach: begin");
402 
403 	/* Allocate, clear, and link in our adapter structure */
404 	dev = iflib_get_dev(ctx);
405 	adapter = iflib_get_softc(ctx);
406 	adapter->dev = dev;
407 	adapter->ctx = ctx;
408 	adapter->hw.back = adapter;
409 	scctx = adapter->shared = iflib_get_softc_ctx(ctx);
410 	adapter->media = iflib_get_media(ctx);
411 	hw = &adapter->hw;
412 
413 	/* Do base PCI setup - map BAR0 */
414 	if (ixv_allocate_pci_resources(ctx)) {
415 		device_printf(dev, "ixv_allocate_pci_resources() failed!\n");
416 		error = ENXIO;
417 		goto err_out;
418 	}
419 
420 	/* SYSCTL APIs */
421 	SYSCTL_ADD_PROC(device_get_sysctl_ctx(dev),
422 	    SYSCTL_CHILDREN(device_get_sysctl_tree(dev)), OID_AUTO, "debug",
423 	    CTLTYPE_INT | CTLFLAG_RW, adapter, 0, ixv_sysctl_debug, "I",
424 	    "Debug Info");
425 
426 	/* Determine hardware revision */
427 	ixv_identify_hardware(ctx);
428 	ixv_init_device_features(adapter);
429 
430 	/* Initialize the shared code */
431 	error = ixgbe_init_ops_vf(hw);
432 	if (error) {
433 		device_printf(dev, "ixgbe_init_ops_vf() failed!\n");
434 		error = EIO;
435 		goto err_out;
436 	}
437 
438 	/* Setup the mailbox */
439 	ixgbe_init_mbx_params_vf(hw);
440 
441 	error = hw->mac.ops.reset_hw(hw);
442 	if (error == IXGBE_ERR_RESET_FAILED)
443 		device_printf(dev, "...reset_hw() failure: Reset Failed!\n");
444 	else if (error)
445 		device_printf(dev, "...reset_hw() failed with error %d\n",
446 		    error);
447 	if (error) {
448 		error = EIO;
449 		goto err_out;
450 	}
451 
452 	error = hw->mac.ops.init_hw(hw);
453 	if (error) {
454 		device_printf(dev, "...init_hw() failed with error %d\n",
455 		    error);
456 		error = EIO;
457 		goto err_out;
458 	}
459 
460 	/* Negotiate mailbox API version */
461 	error = ixv_negotiate_api(adapter);
462 	if (error) {
463 		device_printf(dev,
464 		    "Mailbox API negotiation failed during attach!\n");
465 		goto err_out;
466 	}
467 
468 	/* If no mac address was assigned, make a random one */
469 	if (!ixv_check_ether_addr(hw->mac.addr)) {
470 		u8 addr[ETHER_ADDR_LEN];
471 		arc4rand(&addr, sizeof(addr), 0);
472 		addr[0] &= 0xFE;
473 		addr[0] |= 0x02;
474 		bcopy(addr, hw->mac.addr, sizeof(addr));
475 		bcopy(addr, hw->mac.perm_addr, sizeof(addr));
476 	}
477 
478 	/* Most of the iflib initialization... */
479 
480 	iflib_set_mac(ctx, hw->mac.addr);
481 	switch (adapter->hw.mac.type) {
482 	case ixgbe_mac_X550_vf:
483 	case ixgbe_mac_X550EM_x_vf:
484 	case ixgbe_mac_X550EM_a_vf:
485 		scctx->isc_ntxqsets_max = scctx->isc_nrxqsets_max = 2;
486 		break;
487 	default:
488 		scctx->isc_ntxqsets_max = scctx->isc_nrxqsets_max = 1;
489 	}
490 	scctx->isc_txqsizes[0] =
491 	    roundup2(scctx->isc_ntxd[0] * sizeof(union ixgbe_adv_tx_desc) +
492 	    sizeof(u32), DBA_ALIGN);
493 	scctx->isc_rxqsizes[0] =
494 	    roundup2(scctx->isc_nrxd[0] * sizeof(union ixgbe_adv_rx_desc),
495 	    DBA_ALIGN);
496 	/* XXX */
497 	scctx->isc_tx_csum_flags = CSUM_IP | CSUM_TCP | CSUM_UDP | CSUM_TSO |
498 	    CSUM_IP6_TCP | CSUM_IP6_UDP | CSUM_IP6_TSO;
499 	scctx->isc_tx_nsegments = IXGBE_82599_SCATTER;
500 	scctx->isc_msix_bar = PCIR_BAR(MSIX_82598_BAR);
501 	scctx->isc_tx_tso_segments_max = scctx->isc_tx_nsegments;
502 	scctx->isc_tx_tso_size_max = IXGBE_TSO_SIZE;
503 	scctx->isc_tx_tso_segsize_max = PAGE_SIZE;
504 
505 	scctx->isc_txrx = &ixgbe_txrx;
506 
507 	/*
508 	 * Tell the upper layer(s) we support everything the PF
509 	 * driver does except...
510 	 *   Wake-on-LAN
511 	 */
512 	scctx->isc_capabilities = IXGBE_CAPS;
513 	scctx->isc_capabilities ^= IFCAP_WOL;
514 	scctx->isc_capenable = scctx->isc_capabilities;
515 
516 	INIT_DEBUGOUT("ixv_if_attach_pre: end");
517 
518 	return (0);
519 
520 err_out:
521 	ixv_free_pci_resources(ctx);
522 
523 	return (error);
524 } /* ixv_if_attach_pre */
525 
526 static int
527 ixv_if_attach_post(if_ctx_t ctx)
528 {
529 	struct adapter *adapter = iflib_get_softc(ctx);
530 	device_t       dev = iflib_get_dev(ctx);
531 	int            error = 0;
532 
533 	/* Setup OS specific network interface */
534 	error = ixv_setup_interface(ctx);
535 	if (error) {
536 		device_printf(dev, "Interface setup failed: %d\n", error);
537 		goto end;
538 	}
539 
540 	/* Do the stats setup */
541 	ixv_save_stats(adapter);
542 	ixv_init_stats(adapter);
543 	ixv_add_stats_sysctls(adapter);
544 
545 end:
546 	return error;
547 } /* ixv_if_attach_post */
548 
549 /************************************************************************
550  * ixv_detach - Device removal routine
551  *
552  *   Called when the driver is being removed.
553  *   Stops the adapter and deallocates all the resources
554  *   that were allocated for driver operation.
555  *
556  *   return 0 on success, positive on failure
557  ************************************************************************/
558 static int
559 ixv_if_detach(if_ctx_t ctx)
560 {
561 	INIT_DEBUGOUT("ixv_detach: begin");
562 
563 	ixv_free_pci_resources(ctx);
564 
565 	return (0);
566 } /* ixv_if_detach */
567 
568 /************************************************************************
569  * ixv_if_mtu_set
570  ************************************************************************/
571 static int
572 ixv_if_mtu_set(if_ctx_t ctx, uint32_t mtu)
573 {
574 	struct adapter *adapter = iflib_get_softc(ctx);
575 	struct ifnet   *ifp = iflib_get_ifp(ctx);
576 	int            error = 0;
577 
578 	IOCTL_DEBUGOUT("ioctl: SIOCSIFMTU (Set Interface MTU)");
579 	if (mtu > IXGBE_MAX_FRAME_SIZE - IXGBE_MTU_HDR) {
580 		error = EINVAL;
581 	} else {
582 		ifp->if_mtu = mtu;
583 		adapter->max_frame_size = ifp->if_mtu + IXGBE_MTU_HDR;
584 	}
585 
586 	return error;
587 } /* ixv_if_mtu_set */
588 
589 /************************************************************************
590  * ixv_if_init - Init entry point
591  *
592  *   Used in two ways: It is used by the stack as an init entry
593  *   point in network interface structure. It is also used
594  *   by the driver as a hw/sw initialization routine to get
595  *   to a consistent state.
596  *
597  *   return 0 on success, positive on failure
598  ************************************************************************/
599 static void
600 ixv_if_init(if_ctx_t ctx)
601 {
602 	struct adapter  *adapter = iflib_get_softc(ctx);
603 	struct ifnet    *ifp = iflib_get_ifp(ctx);
604 	device_t        dev = iflib_get_dev(ctx);
605 	struct ixgbe_hw *hw = &adapter->hw;
606 	int             error = 0;
607 
608 	INIT_DEBUGOUT("ixv_if_init: begin");
609 	hw->adapter_stopped = FALSE;
610 	hw->mac.ops.stop_adapter(hw);
611 
612 	/* reprogram the RAR[0] in case user changed it. */
613 	hw->mac.ops.set_rar(hw, 0, hw->mac.addr, 0, IXGBE_RAH_AV);
614 
615 	/* Get the latest mac address, User can use a LAA */
616 	bcopy(IF_LLADDR(ifp), hw->mac.addr, IXGBE_ETH_LENGTH_OF_ADDRESS);
617 	hw->mac.ops.set_rar(hw, 0, hw->mac.addr, 0, 1);
618 
619 	/* Reset VF and renegotiate mailbox API version */
620 	hw->mac.ops.reset_hw(hw);
621 	hw->mac.ops.start_hw(hw);
622 	error = ixv_negotiate_api(adapter);
623 	if (error) {
624 		device_printf(dev,
625 		    "Mailbox API negotiation failed in if_init!\n");
626 		return;
627 	}
628 
629 	ixv_initialize_transmit_units(ctx);
630 
631 	/* Setup Multicast table */
632 	ixv_if_multi_set(ctx);
633 
634 	/*
635 	 * Determine the correct mbuf pool
636 	 * for doing jumbo/headersplit
637 	 */
638 	if (ifp->if_mtu > ETHERMTU)
639 		adapter->rx_mbuf_sz = MJUMPAGESIZE;
640 	else
641 		adapter->rx_mbuf_sz = MCLBYTES;
642 
643 	/* Configure RX settings */
644 	ixv_initialize_receive_units(ctx);
645 
646 	/* Set up VLAN offload and filter */
647 	ixv_setup_vlan_support(ctx);
648 
649 	/* Set up MSI-X routing */
650 	ixv_configure_ivars(adapter);
651 
652 	/* Set up auto-mask */
653 	IXGBE_WRITE_REG(hw, IXGBE_VTEIAM, IXGBE_EICS_RTX_QUEUE);
654 
655 	/* Set moderation on the Link interrupt */
656 	IXGBE_WRITE_REG(hw, IXGBE_VTEITR(adapter->vector), IXGBE_LINK_ITR);
657 
658 	/* Stats init */
659 	ixv_init_stats(adapter);
660 
661 	/* Config/Enable Link */
662 	hw->mac.ops.check_link(hw, &adapter->link_speed, &adapter->link_up,
663 	    FALSE);
664 
665 	/* And now turn on interrupts */
666 	ixv_if_enable_intr(ctx);
667 
668 	return;
669 } /* ixv_if_init */
670 
671 /************************************************************************
672  * ixv_enable_queue
673  ************************************************************************/
674 static inline void
675 ixv_enable_queue(struct adapter *adapter, u32 vector)
676 {
677 	struct ixgbe_hw *hw = &adapter->hw;
678 	u32             queue = 1 << vector;
679 	u32             mask;
680 
681 	mask = (IXGBE_EIMS_RTX_QUEUE & queue);
682 	IXGBE_WRITE_REG(hw, IXGBE_VTEIMS, mask);
683 } /* ixv_enable_queue */
684 
685 /************************************************************************
686  * ixv_disable_queue
687  ************************************************************************/
688 static inline void
689 ixv_disable_queue(struct adapter *adapter, u32 vector)
690 {
691 	struct ixgbe_hw *hw = &adapter->hw;
692 	u64             queue = (u64)(1 << vector);
693 	u32             mask;
694 
695 	mask = (IXGBE_EIMS_RTX_QUEUE & queue);
696 	IXGBE_WRITE_REG(hw, IXGBE_VTEIMC, mask);
697 } /* ixv_disable_queue */
698 
699 
700 /************************************************************************
701  * ixv_msix_que - MSI-X Queue Interrupt Service routine
702  ************************************************************************/
703 static int
704 ixv_msix_que(void *arg)
705 {
706 	struct ix_rx_queue *que = arg;
707 	struct adapter     *adapter = que->adapter;
708 
709 	ixv_disable_queue(adapter, que->msix);
710 	++que->irqs;
711 
712 	return (FILTER_SCHEDULE_THREAD);
713 } /* ixv_msix_que */
714 
715 /************************************************************************
716  * ixv_msix_mbx
717  ************************************************************************/
718 static int
719 ixv_msix_mbx(void *arg)
720 {
721 	struct adapter  *adapter = arg;
722 	struct ixgbe_hw *hw = &adapter->hw;
723 	u32             reg;
724 
725 	++adapter->link_irq;
726 
727 	/* First get the cause */
728 	reg = IXGBE_READ_REG(hw, IXGBE_VTEICS);
729 	/* Clear interrupt with write */
730 	IXGBE_WRITE_REG(hw, IXGBE_VTEICR, reg);
731 
732 	/* Link status change */
733 	if (reg & IXGBE_EICR_LSC)
734 		iflib_admin_intr_deferred(adapter->ctx);
735 
736 	IXGBE_WRITE_REG(hw, IXGBE_VTEIMS, IXGBE_EIMS_OTHER);
737 
738 	return (FILTER_HANDLED);
739 } /* ixv_msix_mbx */
740 
741 /************************************************************************
742  * ixv_media_status - Media Ioctl callback
743  *
744  *   Called whenever the user queries the status of
745  *   the interface using ifconfig.
746  ************************************************************************/
747 static void
748 ixv_if_media_status(if_ctx_t ctx, struct ifmediareq * ifmr)
749 {
750 	struct adapter *adapter = iflib_get_softc(ctx);
751 
752 	INIT_DEBUGOUT("ixv_media_status: begin");
753 
754 	iflib_admin_intr_deferred(ctx);
755 
756 	ifmr->ifm_status = IFM_AVALID;
757 	ifmr->ifm_active = IFM_ETHER;
758 
759 	if (!adapter->link_active)
760 		return;
761 
762 	ifmr->ifm_status |= IFM_ACTIVE;
763 
764 	switch (adapter->link_speed) {
765 		case IXGBE_LINK_SPEED_1GB_FULL:
766 			ifmr->ifm_active |= IFM_1000_T | IFM_FDX;
767 			break;
768 		case IXGBE_LINK_SPEED_10GB_FULL:
769 			ifmr->ifm_active |= IFM_10G_T | IFM_FDX;
770 			break;
771 		case IXGBE_LINK_SPEED_100_FULL:
772 			ifmr->ifm_active |= IFM_100_TX | IFM_FDX;
773 			break;
774 		case IXGBE_LINK_SPEED_10_FULL:
775 			ifmr->ifm_active |= IFM_10_T | IFM_FDX;
776 			break;
777 	}
778 } /* ixv_if_media_status */
779 
780 /************************************************************************
781  * ixv_if_media_change - Media Ioctl callback
782  *
783  *   Called when the user changes speed/duplex using
784  *   media/mediopt option with ifconfig.
785  ************************************************************************/
786 static int
787 ixv_if_media_change(if_ctx_t ctx)
788 {
789 	struct adapter *adapter = iflib_get_softc(ctx);
790 	struct ifmedia *ifm = iflib_get_media(ctx);
791 
792 	INIT_DEBUGOUT("ixv_media_change: begin");
793 
794 	if (IFM_TYPE(ifm->ifm_media) != IFM_ETHER)
795 		return (EINVAL);
796 
797 	switch (IFM_SUBTYPE(ifm->ifm_media)) {
798 	case IFM_AUTO:
799 		break;
800 	default:
801 		device_printf(adapter->dev, "Only auto media type\n");
802 		return (EINVAL);
803 	}
804 
805 	return (0);
806 } /* ixv_if_media_change */
807 
808 
809 /************************************************************************
810  * ixv_negotiate_api
811  *
812  *   Negotiate the Mailbox API with the PF;
813  *   start with the most featured API first.
814  ************************************************************************/
815 static int
816 ixv_negotiate_api(struct adapter *adapter)
817 {
818 	struct ixgbe_hw *hw = &adapter->hw;
819 	int             mbx_api[] = { ixgbe_mbox_api_11,
820 	                              ixgbe_mbox_api_10,
821 	                              ixgbe_mbox_api_unknown };
822 	int             i = 0;
823 
824 	while (mbx_api[i] != ixgbe_mbox_api_unknown) {
825 		if (ixgbevf_negotiate_api_version(hw, mbx_api[i]) == 0)
826 			return (0);
827 		i++;
828 	}
829 
830 	return (EINVAL);
831 } /* ixv_negotiate_api */
832 
833 
834 /************************************************************************
835  * ixv_if_multi_set - Multicast Update
836  *
837  *   Called whenever multicast address list is updated.
838  ************************************************************************/
839 static void
840 ixv_if_multi_set(if_ctx_t ctx)
841 {
842 	u8       mta[MAX_NUM_MULTICAST_ADDRESSES * IXGBE_ETH_LENGTH_OF_ADDRESS];
843 	struct adapter     *adapter = iflib_get_softc(ctx);
844 	u8                 *update_ptr;
845 	struct ifmultiaddr *ifma;
846 	if_t               ifp = iflib_get_ifp(ctx);
847 	int                mcnt = 0;
848 
849 	IOCTL_DEBUGOUT("ixv_if_multi_set: begin");
850 
851 	CK_STAILQ_FOREACH(ifma, &ifp->if_multiaddrs, ifma_link) {
852 		if (ifma->ifma_addr->sa_family != AF_LINK)
853 			continue;
854 		bcopy(LLADDR((struct sockaddr_dl *)ifma->ifma_addr),
855 		    &mta[mcnt * IXGBE_ETH_LENGTH_OF_ADDRESS],
856 		    IXGBE_ETH_LENGTH_OF_ADDRESS);
857 		mcnt++;
858 	}
859 
860 	update_ptr = mta;
861 
862 	adapter->hw.mac.ops.update_mc_addr_list(&adapter->hw, update_ptr, mcnt,
863 	    ixv_mc_array_itr, TRUE);
864 } /* ixv_if_multi_set */
865 
866 /************************************************************************
867  * ixv_mc_array_itr
868  *
869  *   An iterator function needed by the multicast shared code.
870  *   It feeds the shared code routine the addresses in the
871  *   array of ixv_set_multi() one by one.
872  ************************************************************************/
873 static u8 *
874 ixv_mc_array_itr(struct ixgbe_hw *hw, u8 **update_ptr, u32 *vmdq)
875 {
876 	u8 *addr = *update_ptr;
877 	u8 *newptr;
878 
879 	*vmdq = 0;
880 
881 	newptr = addr + IXGBE_ETH_LENGTH_OF_ADDRESS;
882 	*update_ptr = newptr;
883 
884 	return addr;
885 } /* ixv_mc_array_itr */
886 
887 /************************************************************************
888  * ixv_if_local_timer - Timer routine
889  *
890  *   Checks for link status, updates statistics,
891  *   and runs the watchdog check.
892  ************************************************************************/
893 static void
894 ixv_if_local_timer(if_ctx_t ctx, uint16_t qid)
895 {
896 	if (qid != 0)
897 		return;
898 
899 	/* Fire off the adminq task */
900 	iflib_admin_intr_deferred(ctx);
901 } /* ixv_if_local_timer */
902 
903 /************************************************************************
904  * ixv_if_update_admin_status - Update OS on link state
905  *
906  * Note: Only updates the OS on the cached link state.
907  *       The real check of the hardware only happens with
908  *       a link interrupt.
909  ************************************************************************/
910 static void
911 ixv_if_update_admin_status(if_ctx_t ctx)
912 {
913 	struct adapter *adapter = iflib_get_softc(ctx);
914 	device_t       dev = iflib_get_dev(ctx);
915 	s32            status;
916 
917 	adapter->hw.mac.get_link_status = TRUE;
918 
919 	status = ixgbe_check_link(&adapter->hw, &adapter->link_speed,
920 	    &adapter->link_up, FALSE);
921 
922 	if (status != IXGBE_SUCCESS && adapter->hw.adapter_stopped == FALSE) {
923 		/* Mailbox's Clear To Send status is lost or timeout occurred.
924 		 * We need reinitialization. */
925 		iflib_get_ifp(ctx)->if_init(ctx);
926 	}
927 
928 	if (adapter->link_up) {
929 		if (adapter->link_active == FALSE) {
930 			if (bootverbose)
931 				device_printf(dev, "Link is up %d Gbps %s \n",
932 				    ((adapter->link_speed == 128) ? 10 : 1),
933 				    "Full Duplex");
934 			adapter->link_active = TRUE;
935 			iflib_link_state_change(ctx, LINK_STATE_UP,
936 			    IF_Gbps(10));
937 		}
938 	} else { /* Link down */
939 		if (adapter->link_active == TRUE) {
940 			if (bootverbose)
941 				device_printf(dev, "Link is Down\n");
942 			iflib_link_state_change(ctx, LINK_STATE_DOWN,  0);
943 			adapter->link_active = FALSE;
944 		}
945 	}
946 
947 	/* Stats Update */
948 	ixv_update_stats(adapter);
949 } /* ixv_if_update_admin_status */
950 
951 
952 /************************************************************************
953  * ixv_if_stop - Stop the hardware
954  *
955  *   Disables all traffic on the adapter by issuing a
956  *   global reset on the MAC and deallocates TX/RX buffers.
957  ************************************************************************/
958 static void
959 ixv_if_stop(if_ctx_t ctx)
960 {
961 	struct adapter  *adapter = iflib_get_softc(ctx);
962 	struct ixgbe_hw *hw = &adapter->hw;
963 
964 	INIT_DEBUGOUT("ixv_stop: begin\n");
965 
966 	ixv_if_disable_intr(ctx);
967 
968 	hw->mac.ops.reset_hw(hw);
969 	adapter->hw.adapter_stopped = FALSE;
970 	hw->mac.ops.stop_adapter(hw);
971 
972 	/* Update the stack */
973 	adapter->link_up = FALSE;
974 	ixv_if_update_admin_status(ctx);
975 
976 	/* reprogram the RAR[0] in case user changed it. */
977 	hw->mac.ops.set_rar(hw, 0, hw->mac.addr, 0, IXGBE_RAH_AV);
978 } /* ixv_if_stop */
979 
980 
981 /************************************************************************
982  * ixv_identify_hardware - Determine hardware revision.
983  ************************************************************************/
984 static void
985 ixv_identify_hardware(if_ctx_t ctx)
986 {
987 	struct adapter  *adapter = iflib_get_softc(ctx);
988 	device_t        dev = iflib_get_dev(ctx);
989 	struct ixgbe_hw *hw = &adapter->hw;
990 
991 	/* Save off the information about this board */
992 	hw->vendor_id = pci_get_vendor(dev);
993 	hw->device_id = pci_get_device(dev);
994 	hw->revision_id = pci_get_revid(dev);
995 	hw->subsystem_vendor_id = pci_get_subvendor(dev);
996 	hw->subsystem_device_id = pci_get_subdevice(dev);
997 
998 	/* A subset of set_mac_type */
999 	switch (hw->device_id) {
1000 	case IXGBE_DEV_ID_82599_VF:
1001 		hw->mac.type = ixgbe_mac_82599_vf;
1002 		break;
1003 	case IXGBE_DEV_ID_X540_VF:
1004 		hw->mac.type = ixgbe_mac_X540_vf;
1005 		break;
1006 	case IXGBE_DEV_ID_X550_VF:
1007 		hw->mac.type = ixgbe_mac_X550_vf;
1008 		break;
1009 	case IXGBE_DEV_ID_X550EM_X_VF:
1010 		hw->mac.type = ixgbe_mac_X550EM_x_vf;
1011 		break;
1012 	case IXGBE_DEV_ID_X550EM_A_VF:
1013 		hw->mac.type = ixgbe_mac_X550EM_a_vf;
1014 		break;
1015 	default:
1016 		device_printf(dev, "unknown mac type\n");
1017 		hw->mac.type = ixgbe_mac_unknown;
1018 		break;
1019 	}
1020 } /* ixv_identify_hardware */
1021 
1022 /************************************************************************
1023  * ixv_if_msix_intr_assign - Setup MSI-X Interrupt resources and handlers
1024  ************************************************************************/
1025 static int
1026 ixv_if_msix_intr_assign(if_ctx_t ctx, int msix)
1027 {
1028 	struct adapter     *adapter = iflib_get_softc(ctx);
1029 	device_t           dev = iflib_get_dev(ctx);
1030 	struct ix_rx_queue *rx_que = adapter->rx_queues;
1031 	struct ix_tx_queue *tx_que;
1032 	int                error, rid, vector = 0;
1033 	char               buf[16];
1034 
1035 	for (int i = 0; i < adapter->num_rx_queues; i++, vector++, rx_que++) {
1036 		rid = vector + 1;
1037 
1038 		snprintf(buf, sizeof(buf), "rxq%d", i);
1039 		error = iflib_irq_alloc_generic(ctx, &rx_que->que_irq, rid,
1040 		    IFLIB_INTR_RX, ixv_msix_que, rx_que, rx_que->rxr.me, buf);
1041 
1042 		if (error) {
1043 			device_printf(iflib_get_dev(ctx),
1044 			    "Failed to allocate que int %d err: %d", i, error);
1045 			adapter->num_rx_queues = i + 1;
1046 			goto fail;
1047 		}
1048 
1049 		rx_que->msix = vector;
1050 		adapter->active_queues |= (u64)(1 << rx_que->msix);
1051 
1052 	}
1053 
1054 	for (int i = 0; i < adapter->num_tx_queues; i++) {
1055 		snprintf(buf, sizeof(buf), "txq%d", i);
1056 		tx_que = &adapter->tx_queues[i];
1057 		tx_que->msix = i % adapter->num_rx_queues;
1058 		iflib_softirq_alloc_generic(ctx,
1059 		    &adapter->rx_queues[tx_que->msix].que_irq,
1060 		    IFLIB_INTR_TX, tx_que, tx_que->txr.me, buf);
1061 	}
1062 	rid = vector + 1;
1063 	error = iflib_irq_alloc_generic(ctx, &adapter->irq, rid,
1064 	    IFLIB_INTR_ADMIN, ixv_msix_mbx, adapter, 0, "aq");
1065 	if (error) {
1066 		device_printf(iflib_get_dev(ctx),
1067 		    "Failed to register admin handler");
1068 		return (error);
1069 	}
1070 
1071 	adapter->vector = vector;
1072 	/*
1073 	 * Due to a broken design QEMU will fail to properly
1074 	 * enable the guest for MSIX unless the vectors in
1075 	 * the table are all set up, so we must rewrite the
1076 	 * ENABLE in the MSIX control register again at this
1077 	 * point to cause it to successfully initialize us.
1078 	 */
1079 	if (adapter->hw.mac.type == ixgbe_mac_82599_vf) {
1080 		int msix_ctrl;
1081 		pci_find_cap(dev, PCIY_MSIX, &rid);
1082 		rid += PCIR_MSIX_CTRL;
1083 		msix_ctrl = pci_read_config(dev, rid, 2);
1084 		msix_ctrl |= PCIM_MSIXCTRL_MSIX_ENABLE;
1085 		pci_write_config(dev, rid, msix_ctrl, 2);
1086 	}
1087 
1088 	return (0);
1089 
1090 fail:
1091 	iflib_irq_free(ctx, &adapter->irq);
1092 	rx_que = adapter->rx_queues;
1093 	for (int i = 0; i < adapter->num_rx_queues; i++, rx_que++)
1094 		iflib_irq_free(ctx, &rx_que->que_irq);
1095 
1096 	return (error);
1097 } /* ixv_if_msix_intr_assign */
1098 
1099 /************************************************************************
1100  * ixv_allocate_pci_resources
1101  ************************************************************************/
1102 static int
1103 ixv_allocate_pci_resources(if_ctx_t ctx)
1104 {
1105 	struct adapter *adapter = iflib_get_softc(ctx);
1106 	device_t       dev = iflib_get_dev(ctx);
1107 	int            rid;
1108 
1109 	rid = PCIR_BAR(0);
1110 	adapter->pci_mem = bus_alloc_resource_any(dev, SYS_RES_MEMORY, &rid,
1111 	    RF_ACTIVE);
1112 
1113 	if (!(adapter->pci_mem)) {
1114 		device_printf(dev, "Unable to allocate bus resource: memory\n");
1115 		return (ENXIO);
1116 	}
1117 
1118 	adapter->osdep.mem_bus_space_tag = rman_get_bustag(adapter->pci_mem);
1119 	adapter->osdep.mem_bus_space_handle =
1120 	    rman_get_bushandle(adapter->pci_mem);
1121 	adapter->hw.hw_addr = (u8 *)&adapter->osdep.mem_bus_space_handle;
1122 
1123 	return (0);
1124 } /* ixv_allocate_pci_resources */
1125 
1126 /************************************************************************
1127  * ixv_free_pci_resources
1128  ************************************************************************/
1129 static void
1130 ixv_free_pci_resources(if_ctx_t ctx)
1131 {
1132 	struct adapter     *adapter = iflib_get_softc(ctx);
1133 	struct ix_rx_queue *que = adapter->rx_queues;
1134 	device_t           dev = iflib_get_dev(ctx);
1135 
1136 	/* Release all msix queue resources */
1137 	if (adapter->intr_type == IFLIB_INTR_MSIX)
1138 		iflib_irq_free(ctx, &adapter->irq);
1139 
1140 	if (que != NULL) {
1141 		for (int i = 0; i < adapter->num_rx_queues; i++, que++) {
1142 			iflib_irq_free(ctx, &que->que_irq);
1143 		}
1144 	}
1145 
1146 	/* Clean the Legacy or Link interrupt last */
1147 	if (adapter->pci_mem != NULL)
1148 		bus_release_resource(dev, SYS_RES_MEMORY,
1149 				     PCIR_BAR(0), adapter->pci_mem);
1150 } /* ixv_free_pci_resources */
1151 
1152 /************************************************************************
1153  * ixv_setup_interface
1154  *
1155  *   Setup networking device structure and register an interface.
1156  ************************************************************************/
1157 static int
1158 ixv_setup_interface(if_ctx_t ctx)
1159 {
1160 	struct adapter *adapter = iflib_get_softc(ctx);
1161 	if_softc_ctx_t scctx = adapter->shared;
1162 	struct ifnet   *ifp = iflib_get_ifp(ctx);
1163 
1164 	INIT_DEBUGOUT("ixv_setup_interface: begin");
1165 
1166 	if_setbaudrate(ifp, IF_Gbps(10));
1167 	ifp->if_snd.ifq_maxlen = scctx->isc_ntxd[0] - 2;
1168 
1169 
1170 	adapter->max_frame_size = ifp->if_mtu + IXGBE_MTU_HDR;
1171 	ifmedia_add(adapter->media, IFM_ETHER | IFM_AUTO, 0, NULL);
1172 	ifmedia_set(adapter->media, IFM_ETHER | IFM_AUTO);
1173 
1174 	return 0;
1175 } /* ixv_setup_interface */
1176 
1177 /************************************************************************
1178  * ixv_if_get_counter
1179  ************************************************************************/
1180 static uint64_t
1181 ixv_if_get_counter(if_ctx_t ctx, ift_counter cnt)
1182 {
1183 	struct adapter *adapter = iflib_get_softc(ctx);
1184 	if_t           ifp = iflib_get_ifp(ctx);
1185 
1186 	switch (cnt) {
1187 	case IFCOUNTER_IPACKETS:
1188 		return (adapter->ipackets);
1189 	case IFCOUNTER_OPACKETS:
1190 		return (adapter->opackets);
1191 	case IFCOUNTER_IBYTES:
1192 		return (adapter->ibytes);
1193 	case IFCOUNTER_OBYTES:
1194 		return (adapter->obytes);
1195 	case IFCOUNTER_IMCASTS:
1196 		return (adapter->imcasts);
1197 	default:
1198 		return (if_get_counter_default(ifp, cnt));
1199 	}
1200 } /* ixv_if_get_counter */
1201 
1202 /************************************************************************
1203  * ixv_initialize_transmit_units - Enable transmit unit.
1204  ************************************************************************/
1205 static void
1206 ixv_initialize_transmit_units(if_ctx_t ctx)
1207 {
1208 	struct adapter     *adapter = iflib_get_softc(ctx);
1209 	struct ixgbe_hw    *hw = &adapter->hw;
1210 	if_softc_ctx_t     scctx = adapter->shared;
1211 	struct ix_tx_queue *que = adapter->tx_queues;
1212 	int                i;
1213 
1214 	for (i = 0; i < adapter->num_tx_queues; i++, que++) {
1215 		struct tx_ring *txr = &que->txr;
1216 		u64            tdba = txr->tx_paddr;
1217 		u32            txctrl, txdctl;
1218 		int            j = txr->me;
1219 
1220 		/* Set WTHRESH to 8, burst writeback */
1221 		txdctl = IXGBE_READ_REG(hw, IXGBE_VFTXDCTL(j));
1222 		txdctl |= (8 << 16);
1223 		IXGBE_WRITE_REG(hw, IXGBE_VFTXDCTL(j), txdctl);
1224 
1225 		/* Set the HW Tx Head and Tail indices */
1226 		IXGBE_WRITE_REG(&adapter->hw, IXGBE_VFTDH(j), 0);
1227 		IXGBE_WRITE_REG(&adapter->hw, IXGBE_VFTDT(j), 0);
1228 
1229 		/* Set Tx Tail register */
1230 		txr->tail = IXGBE_VFTDT(j);
1231 
1232 		txr->tx_rs_cidx = txr->tx_rs_pidx = txr->tx_cidx_processed = 0;
1233 		for (int k = 0; k < scctx->isc_ntxd[0]; k++)
1234 			txr->tx_rsq[k] = QIDX_INVALID;
1235 
1236 		/* Set Ring parameters */
1237 		IXGBE_WRITE_REG(hw, IXGBE_VFTDBAL(j),
1238 		    (tdba & 0x00000000ffffffffULL));
1239 		IXGBE_WRITE_REG(hw, IXGBE_VFTDBAH(j), (tdba >> 32));
1240 		IXGBE_WRITE_REG(hw, IXGBE_VFTDLEN(j),
1241 		    scctx->isc_ntxd[0] * sizeof(struct ixgbe_legacy_tx_desc));
1242 		txctrl = IXGBE_READ_REG(hw, IXGBE_VFDCA_TXCTRL(j));
1243 		txctrl &= ~IXGBE_DCA_TXCTRL_DESC_WRO_EN;
1244 		IXGBE_WRITE_REG(hw, IXGBE_VFDCA_TXCTRL(j), txctrl);
1245 
1246 		/* Now enable */
1247 		txdctl = IXGBE_READ_REG(hw, IXGBE_VFTXDCTL(j));
1248 		txdctl |= IXGBE_TXDCTL_ENABLE;
1249 		IXGBE_WRITE_REG(hw, IXGBE_VFTXDCTL(j), txdctl);
1250 	}
1251 
1252 	return;
1253 } /* ixv_initialize_transmit_units */
1254 
1255 /************************************************************************
1256  * ixv_initialize_rss_mapping
1257  ************************************************************************/
1258 static void
1259 ixv_initialize_rss_mapping(struct adapter *adapter)
1260 {
1261 	struct ixgbe_hw *hw = &adapter->hw;
1262 	u32             reta = 0, mrqc, rss_key[10];
1263 	int             queue_id;
1264 	int             i, j;
1265 	u32             rss_hash_config;
1266 
1267 	if (adapter->feat_en & IXGBE_FEATURE_RSS) {
1268 		/* Fetch the configured RSS key */
1269 		rss_getkey((uint8_t *)&rss_key);
1270 	} else {
1271 		/* set up random bits */
1272 		arc4rand(&rss_key, sizeof(rss_key), 0);
1273 	}
1274 
1275 	/* Now fill out hash function seeds */
1276 	for (i = 0; i < 10; i++)
1277 		IXGBE_WRITE_REG(hw, IXGBE_VFRSSRK(i), rss_key[i]);
1278 
1279 	/* Set up the redirection table */
1280 	for (i = 0, j = 0; i < 64; i++, j++) {
1281 		if (j == adapter->num_rx_queues)
1282 			j = 0;
1283 
1284 		if (adapter->feat_en & IXGBE_FEATURE_RSS) {
1285 			/*
1286 			 * Fetch the RSS bucket id for the given indirection
1287 			 * entry. Cap it at the number of configured buckets
1288 			 * (which is num_rx_queues.)
1289 			 */
1290 			queue_id = rss_get_indirection_to_bucket(i);
1291 			queue_id = queue_id % adapter->num_rx_queues;
1292 		} else
1293 			queue_id = j;
1294 
1295 		/*
1296 		 * The low 8 bits are for hash value (n+0);
1297 		 * The next 8 bits are for hash value (n+1), etc.
1298 		 */
1299 		reta >>= 8;
1300 		reta |= ((uint32_t)queue_id) << 24;
1301 		if ((i & 3) == 3) {
1302 			IXGBE_WRITE_REG(hw, IXGBE_VFRETA(i >> 2), reta);
1303 			reta = 0;
1304 		}
1305 	}
1306 
1307 	/* Perform hash on these packet types */
1308 	if (adapter->feat_en & IXGBE_FEATURE_RSS)
1309 		rss_hash_config = rss_gethashconfig();
1310 	else {
1311 		/*
1312 		 * Disable UDP - IP fragments aren't currently being handled
1313 		 * and so we end up with a mix of 2-tuple and 4-tuple
1314 		 * traffic.
1315 		 */
1316 		rss_hash_config = RSS_HASHTYPE_RSS_IPV4
1317 		                | RSS_HASHTYPE_RSS_TCP_IPV4
1318 		                | RSS_HASHTYPE_RSS_IPV6
1319 		                | RSS_HASHTYPE_RSS_TCP_IPV6;
1320 	}
1321 
1322 	mrqc = IXGBE_MRQC_RSSEN;
1323 	if (rss_hash_config & RSS_HASHTYPE_RSS_IPV4)
1324 		mrqc |= IXGBE_MRQC_RSS_FIELD_IPV4;
1325 	if (rss_hash_config & RSS_HASHTYPE_RSS_TCP_IPV4)
1326 		mrqc |= IXGBE_MRQC_RSS_FIELD_IPV4_TCP;
1327 	if (rss_hash_config & RSS_HASHTYPE_RSS_IPV6)
1328 		mrqc |= IXGBE_MRQC_RSS_FIELD_IPV6;
1329 	if (rss_hash_config & RSS_HASHTYPE_RSS_TCP_IPV6)
1330 		mrqc |= IXGBE_MRQC_RSS_FIELD_IPV6_TCP;
1331 	if (rss_hash_config & RSS_HASHTYPE_RSS_IPV6_EX)
1332 		device_printf(adapter->dev, "%s: RSS_HASHTYPE_RSS_IPV6_EX defined, but not supported\n",
1333 		    __func__);
1334 	if (rss_hash_config & RSS_HASHTYPE_RSS_TCP_IPV6_EX)
1335 		device_printf(adapter->dev, "%s: RSS_HASHTYPE_RSS_TCP_IPV6_EX defined, but not supported\n",
1336 		    __func__);
1337 	if (rss_hash_config & RSS_HASHTYPE_RSS_UDP_IPV4)
1338 		mrqc |= IXGBE_MRQC_RSS_FIELD_IPV4_UDP;
1339 	if (rss_hash_config & RSS_HASHTYPE_RSS_UDP_IPV6)
1340 		mrqc |= IXGBE_MRQC_RSS_FIELD_IPV6_UDP;
1341 	if (rss_hash_config & RSS_HASHTYPE_RSS_UDP_IPV6_EX)
1342 		device_printf(adapter->dev, "%s: RSS_HASHTYPE_RSS_UDP_IPV6_EX defined, but not supported\n",
1343 		    __func__);
1344 	IXGBE_WRITE_REG(hw, IXGBE_VFMRQC, mrqc);
1345 } /* ixv_initialize_rss_mapping */
1346 
1347 
1348 /************************************************************************
1349  * ixv_initialize_receive_units - Setup receive registers and features.
1350  ************************************************************************/
1351 static void
1352 ixv_initialize_receive_units(if_ctx_t ctx)
1353 {
1354 	struct adapter     *adapter = iflib_get_softc(ctx);
1355 	if_softc_ctx_t     scctx;
1356 	struct ixgbe_hw    *hw = &adapter->hw;
1357 	struct ifnet       *ifp = iflib_get_ifp(ctx);
1358 	struct ix_rx_queue *que = adapter->rx_queues;
1359 	u32                bufsz, psrtype;
1360 
1361 	if (ifp->if_mtu > ETHERMTU)
1362 		bufsz = 4096 >> IXGBE_SRRCTL_BSIZEPKT_SHIFT;
1363 	else
1364 		bufsz = 2048 >> IXGBE_SRRCTL_BSIZEPKT_SHIFT;
1365 
1366 	psrtype = IXGBE_PSRTYPE_TCPHDR
1367 	        | IXGBE_PSRTYPE_UDPHDR
1368 	        | IXGBE_PSRTYPE_IPV4HDR
1369 	        | IXGBE_PSRTYPE_IPV6HDR
1370 	        | IXGBE_PSRTYPE_L2HDR;
1371 
1372 	if (adapter->num_rx_queues > 1)
1373 		psrtype |= 1 << 29;
1374 
1375 	IXGBE_WRITE_REG(hw, IXGBE_VFPSRTYPE, psrtype);
1376 
1377 	/* Tell PF our max_frame size */
1378 	if (ixgbevf_rlpml_set_vf(hw, adapter->max_frame_size) != 0) {
1379 		device_printf(adapter->dev, "There is a problem with the PF setup.  It is likely the receive unit for this VF will not function correctly.\n");
1380 	}
1381 	scctx = adapter->shared;
1382 
1383 	for (int i = 0; i < adapter->num_rx_queues; i++, que++) {
1384 		struct rx_ring *rxr = &que->rxr;
1385 		u64            rdba = rxr->rx_paddr;
1386 		u32            reg, rxdctl;
1387 		int            j = rxr->me;
1388 
1389 		/* Disable the queue */
1390 		rxdctl = IXGBE_READ_REG(hw, IXGBE_VFRXDCTL(j));
1391 		rxdctl &= ~IXGBE_RXDCTL_ENABLE;
1392 		IXGBE_WRITE_REG(hw, IXGBE_VFRXDCTL(j), rxdctl);
1393 		for (int k = 0; k < 10; k++) {
1394 			if (IXGBE_READ_REG(hw, IXGBE_VFRXDCTL(j)) &
1395 			    IXGBE_RXDCTL_ENABLE)
1396 				msec_delay(1);
1397 			else
1398 				break;
1399 		}
1400 		wmb();
1401 		/* Setup the Base and Length of the Rx Descriptor Ring */
1402 		IXGBE_WRITE_REG(hw, IXGBE_VFRDBAL(j),
1403 		    (rdba & 0x00000000ffffffffULL));
1404 		IXGBE_WRITE_REG(hw, IXGBE_VFRDBAH(j), (rdba >> 32));
1405 		IXGBE_WRITE_REG(hw, IXGBE_VFRDLEN(j),
1406 		    scctx->isc_nrxd[0] * sizeof(union ixgbe_adv_rx_desc));
1407 
1408 		/* Reset the ring indices */
1409 		IXGBE_WRITE_REG(hw, IXGBE_VFRDH(rxr->me), 0);
1410 		IXGBE_WRITE_REG(hw, IXGBE_VFRDT(rxr->me), 0);
1411 
1412 		/* Set up the SRRCTL register */
1413 		reg = IXGBE_READ_REG(hw, IXGBE_VFSRRCTL(j));
1414 		reg &= ~IXGBE_SRRCTL_BSIZEHDR_MASK;
1415 		reg &= ~IXGBE_SRRCTL_BSIZEPKT_MASK;
1416 		reg |= bufsz;
1417 		reg |= IXGBE_SRRCTL_DESCTYPE_ADV_ONEBUF;
1418 		IXGBE_WRITE_REG(hw, IXGBE_VFSRRCTL(j), reg);
1419 
1420 		/* Capture Rx Tail index */
1421 		rxr->tail = IXGBE_VFRDT(rxr->me);
1422 
1423 		/* Do the queue enabling last */
1424 		rxdctl |= IXGBE_RXDCTL_ENABLE | IXGBE_RXDCTL_VME;
1425 		IXGBE_WRITE_REG(hw, IXGBE_VFRXDCTL(j), rxdctl);
1426 		for (int l = 0; l < 10; l++) {
1427 			if (IXGBE_READ_REG(hw, IXGBE_VFRXDCTL(j)) &
1428 			    IXGBE_RXDCTL_ENABLE)
1429 				break;
1430 			msec_delay(1);
1431 		}
1432 		wmb();
1433 
1434 		/* Set the Tail Pointer */
1435 #ifdef DEV_NETMAP
1436 		/*
1437 		 * In netmap mode, we must preserve the buffers made
1438 		 * available to userspace before the if_init()
1439 		 * (this is true by default on the TX side, because
1440 		 * init makes all buffers available to userspace).
1441 		 *
1442 		 * netmap_reset() and the device specific routines
1443 		 * (e.g. ixgbe_setup_receive_rings()) map these
1444 		 * buffers at the end of the NIC ring, so here we
1445 		 * must set the RDT (tail) register to make sure
1446 		 * they are not overwritten.
1447 		 *
1448 		 * In this driver the NIC ring starts at RDH = 0,
1449 		 * RDT points to the last slot available for reception (?),
1450 		 * so RDT = num_rx_desc - 1 means the whole ring is available.
1451 		 */
1452 		if (ifp->if_capenable & IFCAP_NETMAP) {
1453 			struct netmap_adapter *na = NA(ifp);
1454 			struct netmap_kring *kring = na->rx_rings[j];
1455 			int t = na->num_rx_desc - 1 - nm_kr_rxspace(kring);
1456 
1457 			IXGBE_WRITE_REG(hw, IXGBE_VFRDT(rxr->me), t);
1458 		} else
1459 #endif /* DEV_NETMAP */
1460 			IXGBE_WRITE_REG(hw, IXGBE_VFRDT(rxr->me),
1461 			    scctx->isc_nrxd[0] - 1);
1462 	}
1463 
1464 	ixv_initialize_rss_mapping(adapter);
1465 } /* ixv_initialize_receive_units */
1466 
1467 /************************************************************************
1468  * ixv_setup_vlan_support
1469  ************************************************************************/
1470 static void
1471 ixv_setup_vlan_support(if_ctx_t ctx)
1472 {
1473 	struct adapter  *adapter = iflib_get_softc(ctx);
1474 	struct ixgbe_hw *hw = &adapter->hw;
1475 	u32             ctrl, vid, vfta, retry;
1476 
1477 	/*
1478 	 * We get here thru if_init, meaning
1479 	 * a soft reset, this has already cleared
1480 	 * the VFTA and other state, so if there
1481 	 * have been no vlan's registered do nothing.
1482 	 */
1483 	if (adapter->num_vlans == 0)
1484 		return;
1485 
1486 	/* Enable the queues */
1487 	for (int i = 0; i < adapter->num_rx_queues; i++) {
1488 		ctrl = IXGBE_READ_REG(hw, IXGBE_VFRXDCTL(i));
1489 		ctrl |= IXGBE_RXDCTL_VME;
1490 		IXGBE_WRITE_REG(hw, IXGBE_VFRXDCTL(i), ctrl);
1491 		/*
1492 		 * Let Rx path know that it needs to store VLAN tag
1493 		 * as part of extra mbuf info.
1494 		 */
1495 		adapter->rx_queues[i].rxr.vtag_strip = TRUE;
1496 	}
1497 
1498 	/*
1499 	 * A soft reset zero's out the VFTA, so
1500 	 * we need to repopulate it now.
1501 	 */
1502 	for (int i = 0; i < IXGBE_VFTA_SIZE; i++) {
1503 		if (ixv_shadow_vfta[i] == 0)
1504 			continue;
1505 		vfta = ixv_shadow_vfta[i];
1506 		/*
1507 		 * Reconstruct the vlan id's
1508 		 * based on the bits set in each
1509 		 * of the array ints.
1510 		 */
1511 		for (int j = 0; j < 32; j++) {
1512 			retry = 0;
1513 			if ((vfta & (1 << j)) == 0)
1514 				continue;
1515 			vid = (i * 32) + j;
1516 			/* Call the shared code mailbox routine */
1517 			while (hw->mac.ops.set_vfta(hw, vid, 0, TRUE, FALSE)) {
1518 				if (++retry > 5)
1519 					break;
1520 			}
1521 		}
1522 	}
1523 } /* ixv_setup_vlan_support */
1524 
1525 /************************************************************************
1526  * ixv_if_register_vlan
1527  *
1528  *   Run via a vlan config EVENT, it enables us to use the
1529  *   HW Filter table since we can get the vlan id. This just
1530  *   creates the entry in the soft version of the VFTA, init
1531  *   will repopulate the real table.
1532  ************************************************************************/
1533 static void
1534 ixv_if_register_vlan(if_ctx_t ctx, u16 vtag)
1535 {
1536 	struct adapter *adapter = iflib_get_softc(ctx);
1537 	u16            index, bit;
1538 
1539 	index = (vtag >> 5) & 0x7F;
1540 	bit = vtag & 0x1F;
1541 	ixv_shadow_vfta[index] |= (1 << bit);
1542 	++adapter->num_vlans;
1543 } /* ixv_if_register_vlan */
1544 
1545 /************************************************************************
1546  * ixv_if_unregister_vlan
1547  *
1548  *   Run via a vlan unconfig EVENT, remove our entry
1549  *   in the soft vfta.
1550  ************************************************************************/
1551 static void
1552 ixv_if_unregister_vlan(if_ctx_t ctx, u16 vtag)
1553 {
1554 	struct adapter *adapter = iflib_get_softc(ctx);
1555 	u16            index, bit;
1556 
1557 	index = (vtag >> 5) & 0x7F;
1558 	bit = vtag & 0x1F;
1559 	ixv_shadow_vfta[index] &= ~(1 << bit);
1560 	--adapter->num_vlans;
1561 } /* ixv_if_unregister_vlan */
1562 
1563 /************************************************************************
1564  * ixv_if_enable_intr
1565  ************************************************************************/
1566 static void
1567 ixv_if_enable_intr(if_ctx_t ctx)
1568 {
1569 	struct adapter  *adapter = iflib_get_softc(ctx);
1570 	struct ixgbe_hw *hw = &adapter->hw;
1571 	struct ix_rx_queue *que = adapter->rx_queues;
1572 	u32             mask = (IXGBE_EIMS_ENABLE_MASK & ~IXGBE_EIMS_RTX_QUEUE);
1573 
1574 	IXGBE_WRITE_REG(hw, IXGBE_VTEIMS, mask);
1575 
1576 	mask = IXGBE_EIMS_ENABLE_MASK;
1577 	mask &= ~(IXGBE_EIMS_OTHER | IXGBE_EIMS_LSC);
1578 	IXGBE_WRITE_REG(hw, IXGBE_VTEIAC, mask);
1579 
1580 	for (int i = 0; i < adapter->num_rx_queues; i++, que++)
1581 		ixv_enable_queue(adapter, que->msix);
1582 
1583 	IXGBE_WRITE_FLUSH(hw);
1584 } /* ixv_if_enable_intr */
1585 
1586 /************************************************************************
1587  * ixv_if_disable_intr
1588  ************************************************************************/
1589 static void
1590 ixv_if_disable_intr(if_ctx_t ctx)
1591 {
1592 	struct adapter *adapter = iflib_get_softc(ctx);
1593 	IXGBE_WRITE_REG(&adapter->hw, IXGBE_VTEIAC, 0);
1594 	IXGBE_WRITE_REG(&adapter->hw, IXGBE_VTEIMC, ~0);
1595 	IXGBE_WRITE_FLUSH(&adapter->hw);
1596 } /* ixv_if_disable_intr */
1597 
1598 /************************************************************************
1599  * ixv_if_rx_queue_intr_enable
1600  ************************************************************************/
1601 static int
1602 ixv_if_rx_queue_intr_enable(if_ctx_t ctx, uint16_t rxqid)
1603 {
1604 	struct adapter	*adapter = iflib_get_softc(ctx);
1605 	struct ix_rx_queue *que = &adapter->rx_queues[rxqid];
1606 
1607 	ixv_enable_queue(adapter, que->rxr.me);
1608 
1609 	return (0);
1610 } /* ixv_if_rx_queue_intr_enable */
1611 
1612 /************************************************************************
1613  * ixv_set_ivar
1614  *
1615  *   Setup the correct IVAR register for a particular MSI-X interrupt
1616  *    - entry is the register array entry
1617  *    - vector is the MSI-X vector for this queue
1618  *    - type is RX/TX/MISC
1619  ************************************************************************/
1620 static void
1621 ixv_set_ivar(struct adapter *adapter, u8 entry, u8 vector, s8 type)
1622 {
1623 	struct ixgbe_hw *hw = &adapter->hw;
1624 	u32             ivar, index;
1625 
1626 	vector |= IXGBE_IVAR_ALLOC_VAL;
1627 
1628 	if (type == -1) { /* MISC IVAR */
1629 		ivar = IXGBE_READ_REG(hw, IXGBE_VTIVAR_MISC);
1630 		ivar &= ~0xFF;
1631 		ivar |= vector;
1632 		IXGBE_WRITE_REG(hw, IXGBE_VTIVAR_MISC, ivar);
1633 	} else {          /* RX/TX IVARS */
1634 		index = (16 * (entry & 1)) + (8 * type);
1635 		ivar = IXGBE_READ_REG(hw, IXGBE_VTIVAR(entry >> 1));
1636 		ivar &= ~(0xFF << index);
1637 		ivar |= (vector << index);
1638 		IXGBE_WRITE_REG(hw, IXGBE_VTIVAR(entry >> 1), ivar);
1639 	}
1640 } /* ixv_set_ivar */
1641 
1642 /************************************************************************
1643  * ixv_configure_ivars
1644  ************************************************************************/
1645 static void
1646 ixv_configure_ivars(struct adapter *adapter)
1647 {
1648 	struct ix_rx_queue *que = adapter->rx_queues;
1649 
1650 	MPASS(adapter->num_rx_queues == adapter->num_tx_queues);
1651 
1652 	for (int i = 0; i < adapter->num_rx_queues; i++, que++) {
1653 		/* First the RX queue entry */
1654 		ixv_set_ivar(adapter, i, que->msix, 0);
1655 		/* ... and the TX */
1656 		ixv_set_ivar(adapter, i, que->msix, 1);
1657 		/* Set an initial value in EITR */
1658 		IXGBE_WRITE_REG(&adapter->hw, IXGBE_VTEITR(que->msix),
1659 		    IXGBE_EITR_DEFAULT);
1660 	}
1661 
1662 	/* For the mailbox interrupt */
1663 	ixv_set_ivar(adapter, 1, adapter->vector, -1);
1664 } /* ixv_configure_ivars */
1665 
1666 /************************************************************************
1667  * ixv_save_stats
1668  *
1669  *   The VF stats registers never have a truly virgin
1670  *   starting point, so this routine tries to make an
1671  *   artificial one, marking ground zero on attach as
1672  *   it were.
1673  ************************************************************************/
1674 static void
1675 ixv_save_stats(struct adapter *adapter)
1676 {
1677 	if (adapter->stats.vf.vfgprc || adapter->stats.vf.vfgptc) {
1678 		adapter->stats.vf.saved_reset_vfgprc +=
1679 		    adapter->stats.vf.vfgprc - adapter->stats.vf.base_vfgprc;
1680 		adapter->stats.vf.saved_reset_vfgptc +=
1681 		    adapter->stats.vf.vfgptc - adapter->stats.vf.base_vfgptc;
1682 		adapter->stats.vf.saved_reset_vfgorc +=
1683 		    adapter->stats.vf.vfgorc - adapter->stats.vf.base_vfgorc;
1684 		adapter->stats.vf.saved_reset_vfgotc +=
1685 		    adapter->stats.vf.vfgotc - adapter->stats.vf.base_vfgotc;
1686 		adapter->stats.vf.saved_reset_vfmprc +=
1687 		    adapter->stats.vf.vfmprc - adapter->stats.vf.base_vfmprc;
1688 	}
1689 } /* ixv_save_stats */
1690 
1691 /************************************************************************
1692  * ixv_init_stats
1693  ************************************************************************/
1694 static void
1695 ixv_init_stats(struct adapter *adapter)
1696 {
1697 	struct ixgbe_hw *hw = &adapter->hw;
1698 
1699 	adapter->stats.vf.last_vfgprc = IXGBE_READ_REG(hw, IXGBE_VFGPRC);
1700 	adapter->stats.vf.last_vfgorc = IXGBE_READ_REG(hw, IXGBE_VFGORC_LSB);
1701 	adapter->stats.vf.last_vfgorc |=
1702 	    (((u64)(IXGBE_READ_REG(hw, IXGBE_VFGORC_MSB))) << 32);
1703 
1704 	adapter->stats.vf.last_vfgptc = IXGBE_READ_REG(hw, IXGBE_VFGPTC);
1705 	adapter->stats.vf.last_vfgotc = IXGBE_READ_REG(hw, IXGBE_VFGOTC_LSB);
1706 	adapter->stats.vf.last_vfgotc |=
1707 	    (((u64)(IXGBE_READ_REG(hw, IXGBE_VFGOTC_MSB))) << 32);
1708 
1709 	adapter->stats.vf.last_vfmprc = IXGBE_READ_REG(hw, IXGBE_VFMPRC);
1710 
1711 	adapter->stats.vf.base_vfgprc = adapter->stats.vf.last_vfgprc;
1712 	adapter->stats.vf.base_vfgorc = adapter->stats.vf.last_vfgorc;
1713 	adapter->stats.vf.base_vfgptc = adapter->stats.vf.last_vfgptc;
1714 	adapter->stats.vf.base_vfgotc = adapter->stats.vf.last_vfgotc;
1715 	adapter->stats.vf.base_vfmprc = adapter->stats.vf.last_vfmprc;
1716 } /* ixv_init_stats */
1717 
1718 #define UPDATE_STAT_32(reg, last, count)                \
1719 {                                                       \
1720 	u32 current = IXGBE_READ_REG(hw, reg);          \
1721 	if (current < last)                             \
1722 		count += 0x100000000LL;                 \
1723 	last = current;                                 \
1724 	count &= 0xFFFFFFFF00000000LL;                  \
1725 	count |= current;                               \
1726 }
1727 
1728 #define UPDATE_STAT_36(lsb, msb, last, count)           \
1729 {                                                       \
1730 	u64 cur_lsb = IXGBE_READ_REG(hw, lsb);          \
1731 	u64 cur_msb = IXGBE_READ_REG(hw, msb);          \
1732 	u64 current = ((cur_msb << 32) | cur_lsb);      \
1733 	if (current < last)                             \
1734 		count += 0x1000000000LL;                \
1735 	last = current;                                 \
1736 	count &= 0xFFFFFFF000000000LL;                  \
1737 	count |= current;                               \
1738 }
1739 
1740 /************************************************************************
1741  * ixv_update_stats - Update the board statistics counters.
1742  ************************************************************************/
1743 void
1744 ixv_update_stats(struct adapter *adapter)
1745 {
1746 	struct ixgbe_hw *hw = &adapter->hw;
1747 	struct ixgbevf_hw_stats *stats = &adapter->stats.vf;
1748 
1749 	UPDATE_STAT_32(IXGBE_VFGPRC, adapter->stats.vf.last_vfgprc,
1750 	    adapter->stats.vf.vfgprc);
1751 	UPDATE_STAT_32(IXGBE_VFGPTC, adapter->stats.vf.last_vfgptc,
1752 	    adapter->stats.vf.vfgptc);
1753 	UPDATE_STAT_36(IXGBE_VFGORC_LSB, IXGBE_VFGORC_MSB,
1754 	    adapter->stats.vf.last_vfgorc, adapter->stats.vf.vfgorc);
1755 	UPDATE_STAT_36(IXGBE_VFGOTC_LSB, IXGBE_VFGOTC_MSB,
1756 	    adapter->stats.vf.last_vfgotc, adapter->stats.vf.vfgotc);
1757 	UPDATE_STAT_32(IXGBE_VFMPRC, adapter->stats.vf.last_vfmprc,
1758 	    adapter->stats.vf.vfmprc);
1759 
1760 	/* Fill out the OS statistics structure */
1761 	IXGBE_SET_IPACKETS(adapter, stats->vfgprc);
1762 	IXGBE_SET_OPACKETS(adapter, stats->vfgptc);
1763 	IXGBE_SET_IBYTES(adapter, stats->vfgorc);
1764 	IXGBE_SET_OBYTES(adapter, stats->vfgotc);
1765 	IXGBE_SET_IMCASTS(adapter, stats->vfmprc);
1766 } /* ixv_update_stats */
1767 
1768 /************************************************************************
1769  * ixv_add_stats_sysctls - Add statistic sysctls for the VF.
1770  ************************************************************************/
1771 static void
1772 ixv_add_stats_sysctls(struct adapter *adapter)
1773 {
1774 	device_t                dev = adapter->dev;
1775 	struct ix_tx_queue      *tx_que = adapter->tx_queues;
1776 	struct ix_rx_queue      *rx_que = adapter->rx_queues;
1777 	struct sysctl_ctx_list  *ctx = device_get_sysctl_ctx(dev);
1778 	struct sysctl_oid       *tree = device_get_sysctl_tree(dev);
1779 	struct sysctl_oid_list  *child = SYSCTL_CHILDREN(tree);
1780 	struct ixgbevf_hw_stats *stats = &adapter->stats.vf;
1781 	struct sysctl_oid       *stat_node, *queue_node;
1782 	struct sysctl_oid_list  *stat_list, *queue_list;
1783 
1784 #define QUEUE_NAME_LEN 32
1785 	char                    namebuf[QUEUE_NAME_LEN];
1786 
1787 	/* Driver Statistics */
1788 	SYSCTL_ADD_ULONG(ctx, child, OID_AUTO, "watchdog_events",
1789 	    CTLFLAG_RD, &adapter->watchdog_events, "Watchdog timeouts");
1790 	SYSCTL_ADD_ULONG(ctx, child, OID_AUTO, "link_irq",
1791 	    CTLFLAG_RD, &adapter->link_irq, "Link MSI-X IRQ Handled");
1792 
1793 	for (int i = 0; i < adapter->num_tx_queues; i++, tx_que++) {
1794 		struct tx_ring *txr = &tx_que->txr;
1795 		snprintf(namebuf, QUEUE_NAME_LEN, "queue%d", i);
1796 		queue_node = SYSCTL_ADD_NODE(ctx, child, OID_AUTO, namebuf,
1797 		    CTLFLAG_RD, NULL, "Queue Name");
1798 		queue_list = SYSCTL_CHILDREN(queue_node);
1799 
1800 		SYSCTL_ADD_UQUAD(ctx, queue_list, OID_AUTO, "tso_tx",
1801 		    CTLFLAG_RD, &(txr->tso_tx), "TSO Packets");
1802 		SYSCTL_ADD_UQUAD(ctx, queue_list, OID_AUTO, "tx_packets",
1803 		    CTLFLAG_RD, &(txr->total_packets), "TX Packets");
1804 	}
1805 
1806 	for (int i = 0; i < adapter->num_rx_queues; i++, rx_que++) {
1807 		struct rx_ring *rxr = &rx_que->rxr;
1808 		snprintf(namebuf, QUEUE_NAME_LEN, "queue%d", i);
1809 		queue_node = SYSCTL_ADD_NODE(ctx, child, OID_AUTO, namebuf,
1810 		    CTLFLAG_RD, NULL, "Queue Name");
1811 		queue_list = SYSCTL_CHILDREN(queue_node);
1812 
1813 		SYSCTL_ADD_UQUAD(ctx, queue_list, OID_AUTO, "irqs",
1814 		    CTLFLAG_RD, &(rx_que->irqs), "IRQs on queue");
1815 		SYSCTL_ADD_UQUAD(ctx, queue_list, OID_AUTO, "rx_packets",
1816 		    CTLFLAG_RD, &(rxr->rx_packets), "RX packets");
1817 		SYSCTL_ADD_UQUAD(ctx, queue_list, OID_AUTO, "rx_bytes",
1818 		    CTLFLAG_RD, &(rxr->rx_bytes), "RX bytes");
1819 		SYSCTL_ADD_UQUAD(ctx, queue_list, OID_AUTO, "rx_discarded",
1820 		    CTLFLAG_RD, &(rxr->rx_discarded), "Discarded RX packets");
1821 	}
1822 
1823 	stat_node = SYSCTL_ADD_NODE(ctx, child, OID_AUTO, "mac",
1824 	    CTLFLAG_RD, NULL, "VF Statistics (read from HW registers)");
1825 	stat_list = SYSCTL_CHILDREN(stat_node);
1826 
1827 	SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "good_pkts_rcvd",
1828 	    CTLFLAG_RD, &stats->vfgprc, "Good Packets Received");
1829 	SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "good_octets_rcvd",
1830 	    CTLFLAG_RD, &stats->vfgorc, "Good Octets Received");
1831 	SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "mcast_pkts_rcvd",
1832 	    CTLFLAG_RD, &stats->vfmprc, "Multicast Packets Received");
1833 	SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "good_pkts_txd",
1834 	    CTLFLAG_RD, &stats->vfgptc, "Good Packets Transmitted");
1835 	SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "good_octets_txd",
1836 	    CTLFLAG_RD, &stats->vfgotc, "Good Octets Transmitted");
1837 } /* ixv_add_stats_sysctls */
1838 
1839 /************************************************************************
1840  * ixv_print_debug_info
1841  *
1842  *   Called only when em_display_debug_stats is enabled.
1843  *   Provides a way to take a look at important statistics
1844  *   maintained by the driver and hardware.
1845  ************************************************************************/
1846 static void
1847 ixv_print_debug_info(struct adapter *adapter)
1848 {
1849 	device_t        dev = adapter->dev;
1850 	struct ixgbe_hw *hw = &adapter->hw;
1851 
1852 	device_printf(dev, "Error Byte Count = %u \n",
1853 	    IXGBE_READ_REG(hw, IXGBE_ERRBC));
1854 
1855 	device_printf(dev, "MBX IRQ Handled: %lu\n", (long)adapter->link_irq);
1856 } /* ixv_print_debug_info */
1857 
1858 /************************************************************************
1859  * ixv_sysctl_debug
1860  ************************************************************************/
1861 static int
1862 ixv_sysctl_debug(SYSCTL_HANDLER_ARGS)
1863 {
1864 	struct adapter *adapter;
1865 	int            error, result;
1866 
1867 	result = -1;
1868 	error = sysctl_handle_int(oidp, &result, 0, req);
1869 
1870 	if (error || !req->newptr)
1871 		return (error);
1872 
1873 	if (result == 1) {
1874 		adapter = (struct adapter *)arg1;
1875 		ixv_print_debug_info(adapter);
1876 	}
1877 
1878 	return error;
1879 } /* ixv_sysctl_debug */
1880 
1881 /************************************************************************
1882  * ixv_init_device_features
1883  ************************************************************************/
1884 static void
1885 ixv_init_device_features(struct adapter *adapter)
1886 {
1887 	adapter->feat_cap = IXGBE_FEATURE_NETMAP
1888 	                  | IXGBE_FEATURE_VF
1889 	                  | IXGBE_FEATURE_RSS
1890 	                  | IXGBE_FEATURE_LEGACY_TX;
1891 
1892 	/* A tad short on feature flags for VFs, atm. */
1893 	switch (adapter->hw.mac.type) {
1894 	case ixgbe_mac_82599_vf:
1895 		break;
1896 	case ixgbe_mac_X540_vf:
1897 		break;
1898 	case ixgbe_mac_X550_vf:
1899 	case ixgbe_mac_X550EM_x_vf:
1900 	case ixgbe_mac_X550EM_a_vf:
1901 		adapter->feat_cap |= IXGBE_FEATURE_NEEDS_CTXD;
1902 		break;
1903 	default:
1904 		break;
1905 	}
1906 
1907 	/* Enabled by default... */
1908 	/* Is a virtual function (VF) */
1909 	if (adapter->feat_cap & IXGBE_FEATURE_VF)
1910 		adapter->feat_en |= IXGBE_FEATURE_VF;
1911 	/* Netmap */
1912 	if (adapter->feat_cap & IXGBE_FEATURE_NETMAP)
1913 		adapter->feat_en |= IXGBE_FEATURE_NETMAP;
1914 	/* Receive-Side Scaling (RSS) */
1915 	if (adapter->feat_cap & IXGBE_FEATURE_RSS)
1916 		adapter->feat_en |= IXGBE_FEATURE_RSS;
1917 	/* Needs advanced context descriptor regardless of offloads req'd */
1918 	if (adapter->feat_cap & IXGBE_FEATURE_NEEDS_CTXD)
1919 		adapter->feat_en |= IXGBE_FEATURE_NEEDS_CTXD;
1920 } /* ixv_init_device_features */
1921 
1922