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