1 /****************************************************************************** 2 3 Copyright (c) 2001-2015, 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 #ifndef IXGBE_STANDALONE_BUILD 37 #include "opt_inet.h" 38 #include "opt_inet6.h" 39 #include "opt_rss.h" 40 #endif 41 42 #include "ixgbe.h" 43 44 #ifdef RSS 45 #include <net/rss_config.h> 46 #include <netinet/in_rss.h> 47 #endif 48 49 /********************************************************************* 50 * Set this to one to display debug statistics 51 *********************************************************************/ 52 int ixgbe_display_debug_stats = 0; 53 54 /********************************************************************* 55 * Driver version 56 *********************************************************************/ 57 char ixgbe_driver_version[] = "3.1.0"; 58 59 /********************************************************************* 60 * PCI Device ID Table 61 * 62 * Used by probe to select devices to load on 63 * Last field stores an index into ixgbe_strings 64 * Last entry must be all 0s 65 * 66 * { Vendor ID, Device ID, SubVendor ID, SubDevice ID, String Index } 67 *********************************************************************/ 68 69 static ixgbe_vendor_info_t ixgbe_vendor_info_array[] = 70 { 71 {IXGBE_INTEL_VENDOR_ID, IXGBE_DEV_ID_82598AF_DUAL_PORT, 0, 0, 0}, 72 {IXGBE_INTEL_VENDOR_ID, IXGBE_DEV_ID_82598AF_SINGLE_PORT, 0, 0, 0}, 73 {IXGBE_INTEL_VENDOR_ID, IXGBE_DEV_ID_82598EB_CX4, 0, 0, 0}, 74 {IXGBE_INTEL_VENDOR_ID, IXGBE_DEV_ID_82598AT, 0, 0, 0}, 75 {IXGBE_INTEL_VENDOR_ID, IXGBE_DEV_ID_82598AT2, 0, 0, 0}, 76 {IXGBE_INTEL_VENDOR_ID, IXGBE_DEV_ID_82598, 0, 0, 0}, 77 {IXGBE_INTEL_VENDOR_ID, IXGBE_DEV_ID_82598_DA_DUAL_PORT, 0, 0, 0}, 78 {IXGBE_INTEL_VENDOR_ID, IXGBE_DEV_ID_82598_CX4_DUAL_PORT, 0, 0, 0}, 79 {IXGBE_INTEL_VENDOR_ID, IXGBE_DEV_ID_82598EB_XF_LR, 0, 0, 0}, 80 {IXGBE_INTEL_VENDOR_ID, IXGBE_DEV_ID_82598_SR_DUAL_PORT_EM, 0, 0, 0}, 81 {IXGBE_INTEL_VENDOR_ID, IXGBE_DEV_ID_82598EB_SFP_LOM, 0, 0, 0}, 82 {IXGBE_INTEL_VENDOR_ID, IXGBE_DEV_ID_82599_KX4, 0, 0, 0}, 83 {IXGBE_INTEL_VENDOR_ID, IXGBE_DEV_ID_82599_KX4_MEZZ, 0, 0, 0}, 84 {IXGBE_INTEL_VENDOR_ID, IXGBE_DEV_ID_82599_SFP, 0, 0, 0}, 85 {IXGBE_INTEL_VENDOR_ID, IXGBE_DEV_ID_82599_XAUI_LOM, 0, 0, 0}, 86 {IXGBE_INTEL_VENDOR_ID, IXGBE_DEV_ID_82599_CX4, 0, 0, 0}, 87 {IXGBE_INTEL_VENDOR_ID, IXGBE_DEV_ID_82599_T3_LOM, 0, 0, 0}, 88 {IXGBE_INTEL_VENDOR_ID, IXGBE_DEV_ID_82599_COMBO_BACKPLANE, 0, 0, 0}, 89 {IXGBE_INTEL_VENDOR_ID, IXGBE_DEV_ID_82599_BACKPLANE_FCOE, 0, 0, 0}, 90 {IXGBE_INTEL_VENDOR_ID, IXGBE_DEV_ID_82599_SFP_SF2, 0, 0, 0}, 91 {IXGBE_INTEL_VENDOR_ID, IXGBE_DEV_ID_82599_SFP_FCOE, 0, 0, 0}, 92 {IXGBE_INTEL_VENDOR_ID, IXGBE_DEV_ID_82599EN_SFP, 0, 0, 0}, 93 {IXGBE_INTEL_VENDOR_ID, IXGBE_DEV_ID_82599_SFP_SF_QP, 0, 0, 0}, 94 {IXGBE_INTEL_VENDOR_ID, IXGBE_DEV_ID_82599_QSFP_SF_QP, 0, 0, 0}, 95 {IXGBE_INTEL_VENDOR_ID, IXGBE_DEV_ID_X540T, 0, 0, 0}, 96 {IXGBE_INTEL_VENDOR_ID, IXGBE_DEV_ID_X540T1, 0, 0, 0}, 97 {IXGBE_INTEL_VENDOR_ID, IXGBE_DEV_ID_X550T, 0, 0, 0}, 98 {IXGBE_INTEL_VENDOR_ID, IXGBE_DEV_ID_X550EM_X_KR, 0, 0, 0}, 99 {IXGBE_INTEL_VENDOR_ID, IXGBE_DEV_ID_X550EM_X_KX4, 0, 0, 0}, 100 {IXGBE_INTEL_VENDOR_ID, IXGBE_DEV_ID_X550EM_X_10G_T, 0, 0, 0}, 101 /* required last entry */ 102 {0, 0, 0, 0, 0} 103 }; 104 105 /********************************************************************* 106 * Table of branding strings 107 *********************************************************************/ 108 109 static char *ixgbe_strings[] = { 110 "Intel(R) PRO/10GbE PCI-Express Network Driver" 111 }; 112 113 /********************************************************************* 114 * Function prototypes 115 *********************************************************************/ 116 static int ixgbe_probe(device_t); 117 static int ixgbe_attach(device_t); 118 static int ixgbe_detach(device_t); 119 static int ixgbe_shutdown(device_t); 120 static int ixgbe_suspend(device_t); 121 static int ixgbe_resume(device_t); 122 static int ixgbe_ioctl(struct ifnet *, u_long, caddr_t); 123 static void ixgbe_init(void *); 124 static void ixgbe_init_locked(struct adapter *); 125 static void ixgbe_stop(void *); 126 #if __FreeBSD_version >= 1100036 127 static uint64_t ixgbe_get_counter(struct ifnet *, ift_counter); 128 #endif 129 static void ixgbe_add_media_types(struct adapter *); 130 static void ixgbe_media_status(struct ifnet *, struct ifmediareq *); 131 static int ixgbe_media_change(struct ifnet *); 132 static void ixgbe_identify_hardware(struct adapter *); 133 static int ixgbe_allocate_pci_resources(struct adapter *); 134 static void ixgbe_get_slot_info(struct ixgbe_hw *); 135 static int ixgbe_allocate_msix(struct adapter *); 136 static int ixgbe_allocate_legacy(struct adapter *); 137 static int ixgbe_setup_msix(struct adapter *); 138 static void ixgbe_free_pci_resources(struct adapter *); 139 static void ixgbe_local_timer(void *); 140 static int ixgbe_setup_interface(device_t, struct adapter *); 141 static void ixgbe_config_gpie(struct adapter *); 142 static void ixgbe_config_dmac(struct adapter *); 143 static void ixgbe_config_delay_values(struct adapter *); 144 static void ixgbe_config_link(struct adapter *); 145 static void ixgbe_check_eee_support(struct adapter *); 146 static void ixgbe_check_wol_support(struct adapter *); 147 static int ixgbe_setup_low_power_mode(struct adapter *); 148 static void ixgbe_rearm_queues(struct adapter *, u64); 149 150 static void ixgbe_initialize_transmit_units(struct adapter *); 151 static void ixgbe_initialize_receive_units(struct adapter *); 152 static void ixgbe_enable_rx_drop(struct adapter *); 153 static void ixgbe_disable_rx_drop(struct adapter *); 154 155 static void ixgbe_enable_intr(struct adapter *); 156 static void ixgbe_disable_intr(struct adapter *); 157 static void ixgbe_update_stats_counters(struct adapter *); 158 static void ixgbe_set_promisc(struct adapter *); 159 static void ixgbe_set_multi(struct adapter *); 160 static void ixgbe_update_link_status(struct adapter *); 161 static void ixgbe_set_ivar(struct adapter *, u8, u8, s8); 162 static void ixgbe_configure_ivars(struct adapter *); 163 static u8 * ixgbe_mc_array_itr(struct ixgbe_hw *, u8 **, u32 *); 164 165 static void ixgbe_setup_vlan_hw_support(struct adapter *); 166 static void ixgbe_register_vlan(void *, struct ifnet *, u16); 167 static void ixgbe_unregister_vlan(void *, struct ifnet *, u16); 168 169 static void ixgbe_add_device_sysctls(struct adapter *); 170 static void ixgbe_add_hw_stats(struct adapter *); 171 172 /* Sysctl handlers */ 173 static int ixgbe_set_flowcntl(SYSCTL_HANDLER_ARGS); 174 static int ixgbe_set_advertise(SYSCTL_HANDLER_ARGS); 175 static int ixgbe_sysctl_thermal_test(SYSCTL_HANDLER_ARGS); 176 static int ixgbe_sysctl_dmac(SYSCTL_HANDLER_ARGS); 177 static int ixgbe_sysctl_phy_temp(SYSCTL_HANDLER_ARGS); 178 static int ixgbe_sysctl_phy_overtemp_occurred(SYSCTL_HANDLER_ARGS); 179 static int ixgbe_sysctl_wol_enable(SYSCTL_HANDLER_ARGS); 180 static int ixgbe_sysctl_wufc(SYSCTL_HANDLER_ARGS); 181 static int ixgbe_sysctl_eee_enable(SYSCTL_HANDLER_ARGS); 182 static int ixgbe_sysctl_eee_negotiated(SYSCTL_HANDLER_ARGS); 183 static int ixgbe_sysctl_eee_rx_lpi_status(SYSCTL_HANDLER_ARGS); 184 static int ixgbe_sysctl_eee_tx_lpi_status(SYSCTL_HANDLER_ARGS); 185 186 /* Support for pluggable optic modules */ 187 static bool ixgbe_sfp_probe(struct adapter *); 188 static void ixgbe_setup_optics(struct adapter *); 189 190 /* Legacy (single vector interrupt handler */ 191 static void ixgbe_legacy_irq(void *); 192 193 /* The MSI/X Interrupt handlers */ 194 static void ixgbe_msix_que(void *); 195 static void ixgbe_msix_link(void *); 196 197 /* Deferred interrupt tasklets */ 198 static void ixgbe_handle_que(void *, int); 199 static void ixgbe_handle_link(void *, int); 200 static void ixgbe_handle_msf(void *, int); 201 static void ixgbe_handle_mod(void *, int); 202 static void ixgbe_handle_phy(void *, int); 203 204 #ifdef IXGBE_FDIR 205 static void ixgbe_reinit_fdir(void *, int); 206 #endif 207 208 #ifdef PCI_IOV 209 static void ixgbe_ping_all_vfs(struct adapter *); 210 static void ixgbe_handle_mbx(void *, int); 211 static int ixgbe_init_iov(device_t, u16, const nvlist_t *); 212 static void ixgbe_uninit_iov(device_t); 213 static int ixgbe_add_vf(device_t, u16, const nvlist_t *); 214 static void ixgbe_initialize_iov(struct adapter *); 215 static void ixgbe_recalculate_max_frame(struct adapter *); 216 static void ixgbe_init_vf(struct adapter *, struct ixgbe_vf *); 217 #endif /* PCI_IOV */ 218 219 220 /********************************************************************* 221 * FreeBSD Device Interface Entry Points 222 *********************************************************************/ 223 224 static device_method_t ix_methods[] = { 225 /* Device interface */ 226 DEVMETHOD(device_probe, ixgbe_probe), 227 DEVMETHOD(device_attach, ixgbe_attach), 228 DEVMETHOD(device_detach, ixgbe_detach), 229 DEVMETHOD(device_shutdown, ixgbe_shutdown), 230 DEVMETHOD(device_suspend, ixgbe_suspend), 231 DEVMETHOD(device_resume, ixgbe_resume), 232 #ifdef PCI_IOV 233 DEVMETHOD(pci_iov_init, ixgbe_init_iov), 234 DEVMETHOD(pci_iov_uninit, ixgbe_uninit_iov), 235 DEVMETHOD(pci_iov_add_vf, ixgbe_add_vf), 236 #endif /* PCI_IOV */ 237 DEVMETHOD_END 238 }; 239 240 static driver_t ix_driver = { 241 "ix", ix_methods, sizeof(struct adapter), 242 }; 243 244 devclass_t ix_devclass; 245 DRIVER_MODULE(ix, pci, ix_driver, ix_devclass, 0, 0); 246 247 MODULE_DEPEND(ix, pci, 1, 1, 1); 248 MODULE_DEPEND(ix, ether, 1, 1, 1); 249 #ifdef DEV_NETMAP 250 MODULE_DEPEND(ix, netmap, 1, 1, 1); 251 #endif /* DEV_NETMAP */ 252 253 /* 254 ** TUNEABLE PARAMETERS: 255 */ 256 257 static SYSCTL_NODE(_hw, OID_AUTO, ix, CTLFLAG_RD, 0, 258 "IXGBE driver parameters"); 259 260 /* 261 ** AIM: Adaptive Interrupt Moderation 262 ** which means that the interrupt rate 263 ** is varied over time based on the 264 ** traffic for that interrupt vector 265 */ 266 static int ixgbe_enable_aim = TRUE; 267 SYSCTL_INT(_hw_ix, OID_AUTO, enable_aim, CTLFLAG_RWTUN, &ixgbe_enable_aim, 0, 268 "Enable adaptive interrupt moderation"); 269 270 static int ixgbe_max_interrupt_rate = (4000000 / IXGBE_LOW_LATENCY); 271 SYSCTL_INT(_hw_ix, OID_AUTO, max_interrupt_rate, CTLFLAG_RDTUN, 272 &ixgbe_max_interrupt_rate, 0, "Maximum interrupts per second"); 273 274 /* How many packets rxeof tries to clean at a time */ 275 static int ixgbe_rx_process_limit = 256; 276 SYSCTL_INT(_hw_ix, OID_AUTO, rx_process_limit, CTLFLAG_RDTUN, 277 &ixgbe_rx_process_limit, 0, 278 "Maximum number of received packets to process at a time," 279 "-1 means unlimited"); 280 281 /* How many packets txeof tries to clean at a time */ 282 static int ixgbe_tx_process_limit = 256; 283 SYSCTL_INT(_hw_ix, OID_AUTO, tx_process_limit, CTLFLAG_RDTUN, 284 &ixgbe_tx_process_limit, 0, 285 "Maximum number of sent packets to process at a time," 286 "-1 means unlimited"); 287 288 /* 289 ** Smart speed setting, default to on 290 ** this only works as a compile option 291 ** right now as its during attach, set 292 ** this to 'ixgbe_smart_speed_off' to 293 ** disable. 294 */ 295 static int ixgbe_smart_speed = ixgbe_smart_speed_on; 296 297 /* 298 * MSIX should be the default for best performance, 299 * but this allows it to be forced off for testing. 300 */ 301 static int ixgbe_enable_msix = 1; 302 SYSCTL_INT(_hw_ix, OID_AUTO, enable_msix, CTLFLAG_RDTUN, &ixgbe_enable_msix, 0, 303 "Enable MSI-X interrupts"); 304 305 /* 306 * Number of Queues, can be set to 0, 307 * it then autoconfigures based on the 308 * number of cpus with a max of 8. This 309 * can be overriden manually here. 310 */ 311 static int ixgbe_num_queues = 0; 312 SYSCTL_INT(_hw_ix, OID_AUTO, num_queues, CTLFLAG_RDTUN, &ixgbe_num_queues, 0, 313 "Number of queues to configure, 0 indicates autoconfigure"); 314 315 /* 316 ** Number of TX descriptors per ring, 317 ** setting higher than RX as this seems 318 ** the better performing choice. 319 */ 320 static int ixgbe_txd = PERFORM_TXD; 321 SYSCTL_INT(_hw_ix, OID_AUTO, txd, CTLFLAG_RDTUN, &ixgbe_txd, 0, 322 "Number of transmit descriptors per queue"); 323 324 /* Number of RX descriptors per ring */ 325 static int ixgbe_rxd = PERFORM_RXD; 326 SYSCTL_INT(_hw_ix, OID_AUTO, rxd, CTLFLAG_RDTUN, &ixgbe_rxd, 0, 327 "Number of receive descriptors per queue"); 328 329 /* 330 ** Defining this on will allow the use 331 ** of unsupported SFP+ modules, note that 332 ** doing so you are on your own :) 333 */ 334 static int allow_unsupported_sfp = FALSE; 335 TUNABLE_INT("hw.ix.unsupported_sfp", &allow_unsupported_sfp); 336 337 /* Keep running tab on them for sanity check */ 338 static int ixgbe_total_ports; 339 340 #ifdef IXGBE_FDIR 341 /* 342 ** Flow Director actually 'steals' 343 ** part of the packet buffer as its 344 ** filter pool, this variable controls 345 ** how much it uses: 346 ** 0 = 64K, 1 = 128K, 2 = 256K 347 */ 348 static int fdir_pballoc = 1; 349 #endif 350 351 #ifdef DEV_NETMAP 352 /* 353 * The #ifdef DEV_NETMAP / #endif blocks in this file are meant to 354 * be a reference on how to implement netmap support in a driver. 355 * Additional comments are in ixgbe_netmap.h . 356 * 357 * <dev/netmap/ixgbe_netmap.h> contains functions for netmap support 358 * that extend the standard driver. 359 */ 360 #include <dev/netmap/ixgbe_netmap.h> 361 #endif /* DEV_NETMAP */ 362 363 static MALLOC_DEFINE(M_IXGBE, "ix", "ix driver allocations"); 364 365 /********************************************************************* 366 * Device identification routine 367 * 368 * ixgbe_probe determines if the driver should be loaded on 369 * adapter based on PCI vendor/device id of the adapter. 370 * 371 * return BUS_PROBE_DEFAULT on success, positive on failure 372 *********************************************************************/ 373 374 static int 375 ixgbe_probe(device_t dev) 376 { 377 ixgbe_vendor_info_t *ent; 378 379 u16 pci_vendor_id = 0; 380 u16 pci_device_id = 0; 381 u16 pci_subvendor_id = 0; 382 u16 pci_subdevice_id = 0; 383 char adapter_name[256]; 384 385 INIT_DEBUGOUT("ixgbe_probe: begin"); 386 387 pci_vendor_id = pci_get_vendor(dev); 388 if (pci_vendor_id != IXGBE_INTEL_VENDOR_ID) 389 return (ENXIO); 390 391 pci_device_id = pci_get_device(dev); 392 pci_subvendor_id = pci_get_subvendor(dev); 393 pci_subdevice_id = pci_get_subdevice(dev); 394 395 ent = ixgbe_vendor_info_array; 396 while (ent->vendor_id != 0) { 397 if ((pci_vendor_id == ent->vendor_id) && 398 (pci_device_id == ent->device_id) && 399 400 ((pci_subvendor_id == ent->subvendor_id) || 401 (ent->subvendor_id == 0)) && 402 403 ((pci_subdevice_id == ent->subdevice_id) || 404 (ent->subdevice_id == 0))) { 405 sprintf(adapter_name, "%s, Version - %s", 406 ixgbe_strings[ent->index], 407 ixgbe_driver_version); 408 device_set_desc_copy(dev, adapter_name); 409 ++ixgbe_total_ports; 410 return (BUS_PROBE_DEFAULT); 411 } 412 ent++; 413 } 414 return (ENXIO); 415 } 416 417 /********************************************************************* 418 * Device initialization routine 419 * 420 * The attach entry point is called when the driver is being loaded. 421 * This routine identifies the type of hardware, allocates all resources 422 * and initializes the hardware. 423 * 424 * return 0 on success, positive on failure 425 *********************************************************************/ 426 427 static int 428 ixgbe_attach(device_t dev) 429 { 430 struct adapter *adapter; 431 struct ixgbe_hw *hw; 432 int error = 0; 433 u16 csum; 434 u32 ctrl_ext; 435 436 INIT_DEBUGOUT("ixgbe_attach: begin"); 437 438 /* Allocate, clear, and link in our adapter structure */ 439 adapter = device_get_softc(dev); 440 adapter->dev = adapter->osdep.dev = dev; 441 hw = &adapter->hw; 442 443 #ifdef DEV_NETMAP 444 adapter->init_locked = ixgbe_init_locked; 445 adapter->stop_locked = ixgbe_stop; 446 #endif 447 448 /* Core Lock Init*/ 449 IXGBE_CORE_LOCK_INIT(adapter, device_get_nameunit(dev)); 450 451 /* Set up the timer callout */ 452 callout_init_mtx(&adapter->timer, &adapter->core_mtx, 0); 453 454 /* Determine hardware revision */ 455 ixgbe_identify_hardware(adapter); 456 457 /* Do base PCI setup - map BAR0 */ 458 if (ixgbe_allocate_pci_resources(adapter)) { 459 device_printf(dev, "Allocation of PCI resources failed\n"); 460 error = ENXIO; 461 goto err_out; 462 } 463 464 /* Do descriptor calc and sanity checks */ 465 if (((ixgbe_txd * sizeof(union ixgbe_adv_tx_desc)) % DBA_ALIGN) != 0 || 466 ixgbe_txd < MIN_TXD || ixgbe_txd > MAX_TXD) { 467 device_printf(dev, "TXD config issue, using default!\n"); 468 adapter->num_tx_desc = DEFAULT_TXD; 469 } else 470 adapter->num_tx_desc = ixgbe_txd; 471 472 /* 473 ** With many RX rings it is easy to exceed the 474 ** system mbuf allocation. Tuning nmbclusters 475 ** can alleviate this. 476 */ 477 if (nmbclusters > 0) { 478 int s; 479 s = (ixgbe_rxd * adapter->num_queues) * ixgbe_total_ports; 480 if (s > nmbclusters) { 481 device_printf(dev, "RX Descriptors exceed " 482 "system mbuf max, using default instead!\n"); 483 ixgbe_rxd = DEFAULT_RXD; 484 } 485 } 486 487 if (((ixgbe_rxd * sizeof(union ixgbe_adv_rx_desc)) % DBA_ALIGN) != 0 || 488 ixgbe_rxd < MIN_RXD || ixgbe_rxd > MAX_RXD) { 489 device_printf(dev, "RXD config issue, using default!\n"); 490 adapter->num_rx_desc = DEFAULT_RXD; 491 } else 492 adapter->num_rx_desc = ixgbe_rxd; 493 494 /* Allocate our TX/RX Queues */ 495 if (ixgbe_allocate_queues(adapter)) { 496 error = ENOMEM; 497 goto err_out; 498 } 499 500 /* Allocate multicast array memory. */ 501 adapter->mta = malloc(sizeof(*adapter->mta) * 502 MAX_NUM_MULTICAST_ADDRESSES, M_DEVBUF, M_NOWAIT); 503 if (adapter->mta == NULL) { 504 device_printf(dev, "Can not allocate multicast setup array\n"); 505 error = ENOMEM; 506 goto err_late; 507 } 508 509 /* Initialize the shared code */ 510 hw->allow_unsupported_sfp = allow_unsupported_sfp; 511 error = ixgbe_init_shared_code(hw); 512 if (error == IXGBE_ERR_SFP_NOT_PRESENT) { 513 /* 514 ** No optics in this port, set up 515 ** so the timer routine will probe 516 ** for later insertion. 517 */ 518 adapter->sfp_probe = TRUE; 519 error = 0; 520 } else if (error == IXGBE_ERR_SFP_NOT_SUPPORTED) { 521 device_printf(dev,"Unsupported SFP+ module detected!\n"); 522 error = EIO; 523 goto err_late; 524 } else if (error) { 525 device_printf(dev,"Unable to initialize the shared code\n"); 526 error = EIO; 527 goto err_late; 528 } 529 530 /* Make sure we have a good EEPROM before we read from it */ 531 if (ixgbe_validate_eeprom_checksum(&adapter->hw, &csum) < 0) { 532 device_printf(dev,"The EEPROM Checksum Is Not Valid\n"); 533 error = EIO; 534 goto err_late; 535 } 536 537 error = ixgbe_init_hw(hw); 538 switch (error) { 539 case IXGBE_ERR_EEPROM_VERSION: 540 device_printf(dev, "This device is a pre-production adapter/" 541 "LOM. Please be aware there may be issues associated " 542 "with your hardware.\n If you are experiencing problems " 543 "please contact your Intel or hardware representative " 544 "who provided you with this hardware.\n"); 545 break; 546 case IXGBE_ERR_SFP_NOT_SUPPORTED: 547 device_printf(dev,"Unsupported SFP+ Module\n"); 548 error = EIO; 549 goto err_late; 550 case IXGBE_ERR_SFP_NOT_PRESENT: 551 device_printf(dev,"No SFP+ Module found\n"); 552 /* falls thru */ 553 default: 554 break; 555 } 556 557 /* Detect and set physical type */ 558 ixgbe_setup_optics(adapter); 559 560 if ((adapter->msix > 1) && (ixgbe_enable_msix)) 561 error = ixgbe_allocate_msix(adapter); 562 else 563 error = ixgbe_allocate_legacy(adapter); 564 if (error) 565 goto err_late; 566 567 /* Setup OS specific network interface */ 568 if (ixgbe_setup_interface(dev, adapter) != 0) 569 goto err_late; 570 571 /* Initialize statistics */ 572 ixgbe_update_stats_counters(adapter); 573 574 /* Register for VLAN events */ 575 adapter->vlan_attach = EVENTHANDLER_REGISTER(vlan_config, 576 ixgbe_register_vlan, adapter, EVENTHANDLER_PRI_FIRST); 577 adapter->vlan_detach = EVENTHANDLER_REGISTER(vlan_unconfig, 578 ixgbe_unregister_vlan, adapter, EVENTHANDLER_PRI_FIRST); 579 580 /* Check PCIE slot type/speed/width */ 581 ixgbe_get_slot_info(hw); 582 583 584 /* Set an initial default flow control value */ 585 adapter->fc = ixgbe_fc_full; 586 587 #ifdef PCI_IOV 588 if ((hw->mac.type != ixgbe_mac_82598EB) && (adapter->msix > 1)) { 589 nvlist_t *pf_schema, *vf_schema; 590 591 hw->mbx.ops.init_params(hw); 592 pf_schema = pci_iov_schema_alloc_node(); 593 vf_schema = pci_iov_schema_alloc_node(); 594 pci_iov_schema_add_unicast_mac(vf_schema, "mac-addr", 0, NULL); 595 pci_iov_schema_add_bool(vf_schema, "mac-anti-spoof", 596 IOV_SCHEMA_HASDEFAULT, TRUE); 597 pci_iov_schema_add_bool(vf_schema, "allow-set-mac", 598 IOV_SCHEMA_HASDEFAULT, FALSE); 599 pci_iov_schema_add_bool(vf_schema, "allow-promisc", 600 IOV_SCHEMA_HASDEFAULT, FALSE); 601 error = pci_iov_attach(dev, pf_schema, vf_schema); 602 if (error != 0) { 603 device_printf(dev, 604 "Error %d setting up SR-IOV\n", error); 605 } 606 } 607 #endif /* PCI_IOV */ 608 609 /* Check for certain supported features */ 610 ixgbe_check_wol_support(adapter); 611 ixgbe_check_eee_support(adapter); 612 613 /* Add sysctls */ 614 ixgbe_add_device_sysctls(adapter); 615 ixgbe_add_hw_stats(adapter); 616 617 /* let hardware know driver is loaded */ 618 ctrl_ext = IXGBE_READ_REG(hw, IXGBE_CTRL_EXT); 619 ctrl_ext |= IXGBE_CTRL_EXT_DRV_LOAD; 620 IXGBE_WRITE_REG(hw, IXGBE_CTRL_EXT, ctrl_ext); 621 622 #ifdef DEV_NETMAP 623 ixgbe_netmap_attach(adapter); 624 #endif /* DEV_NETMAP */ 625 INIT_DEBUGOUT("ixgbe_attach: end"); 626 return (0); 627 628 err_late: 629 ixgbe_free_transmit_structures(adapter); 630 ixgbe_free_receive_structures(adapter); 631 err_out: 632 if (adapter->ifp != NULL) 633 if_free(adapter->ifp); 634 ixgbe_free_pci_resources(adapter); 635 free(adapter->mta, M_DEVBUF); 636 return (error); 637 } 638 639 /********************************************************************* 640 * Device removal routine 641 * 642 * The detach entry point is called when the driver is being removed. 643 * This routine stops the adapter and deallocates all the resources 644 * that were allocated for driver operation. 645 * 646 * return 0 on success, positive on failure 647 *********************************************************************/ 648 649 static int 650 ixgbe_detach(device_t dev) 651 { 652 struct adapter *adapter = device_get_softc(dev); 653 struct ix_queue *que = adapter->queues; 654 struct tx_ring *txr = adapter->tx_rings; 655 u32 ctrl_ext; 656 657 INIT_DEBUGOUT("ixgbe_detach: begin"); 658 659 /* Make sure VLANS are not using driver */ 660 if (adapter->ifp->if_vlantrunk != NULL) { 661 device_printf(dev,"Vlan in use, detach first\n"); 662 return (EBUSY); 663 } 664 665 #ifdef PCI_IOV 666 if (pci_iov_detach(dev) != 0) { 667 device_printf(dev, "SR-IOV in use; detach first.\n"); 668 return (EBUSY); 669 } 670 #endif /* PCI_IOV */ 671 672 /* Stop the adapter */ 673 IXGBE_CORE_LOCK(adapter); 674 ixgbe_setup_low_power_mode(adapter); 675 IXGBE_CORE_UNLOCK(adapter); 676 677 for (int i = 0; i < adapter->num_queues; i++, que++, txr++) { 678 if (que->tq) { 679 #ifndef IXGBE_LEGACY_TX 680 taskqueue_drain(que->tq, &txr->txq_task); 681 #endif 682 taskqueue_drain(que->tq, &que->que_task); 683 taskqueue_free(que->tq); 684 } 685 } 686 687 /* Drain the Link queue */ 688 if (adapter->tq) { 689 taskqueue_drain(adapter->tq, &adapter->link_task); 690 taskqueue_drain(adapter->tq, &adapter->mod_task); 691 taskqueue_drain(adapter->tq, &adapter->msf_task); 692 #ifdef PCI_IOV 693 taskqueue_drain(adapter->tq, &adapter->mbx_task); 694 #endif 695 taskqueue_drain(adapter->tq, &adapter->phy_task); 696 #ifdef IXGBE_FDIR 697 taskqueue_drain(adapter->tq, &adapter->fdir_task); 698 #endif 699 taskqueue_free(adapter->tq); 700 } 701 702 /* let hardware know driver is unloading */ 703 ctrl_ext = IXGBE_READ_REG(&adapter->hw, IXGBE_CTRL_EXT); 704 ctrl_ext &= ~IXGBE_CTRL_EXT_DRV_LOAD; 705 IXGBE_WRITE_REG(&adapter->hw, IXGBE_CTRL_EXT, ctrl_ext); 706 707 /* Unregister VLAN events */ 708 if (adapter->vlan_attach != NULL) 709 EVENTHANDLER_DEREGISTER(vlan_config, adapter->vlan_attach); 710 if (adapter->vlan_detach != NULL) 711 EVENTHANDLER_DEREGISTER(vlan_unconfig, adapter->vlan_detach); 712 713 ether_ifdetach(adapter->ifp); 714 callout_drain(&adapter->timer); 715 #ifdef DEV_NETMAP 716 netmap_detach(adapter->ifp); 717 #endif /* DEV_NETMAP */ 718 ixgbe_free_pci_resources(adapter); 719 bus_generic_detach(dev); 720 if_free(adapter->ifp); 721 722 ixgbe_free_transmit_structures(adapter); 723 ixgbe_free_receive_structures(adapter); 724 free(adapter->mta, M_DEVBUF); 725 726 IXGBE_CORE_LOCK_DESTROY(adapter); 727 return (0); 728 } 729 730 /********************************************************************* 731 * 732 * Shutdown entry point 733 * 734 **********************************************************************/ 735 736 static int 737 ixgbe_shutdown(device_t dev) 738 { 739 struct adapter *adapter = device_get_softc(dev); 740 int error = 0; 741 742 INIT_DEBUGOUT("ixgbe_shutdown: begin"); 743 744 IXGBE_CORE_LOCK(adapter); 745 error = ixgbe_setup_low_power_mode(adapter); 746 IXGBE_CORE_UNLOCK(adapter); 747 748 return (error); 749 } 750 751 /** 752 * Methods for going from: 753 * D0 -> D3: ixgbe_suspend 754 * D3 -> D0: ixgbe_resume 755 */ 756 static int 757 ixgbe_suspend(device_t dev) 758 { 759 struct adapter *adapter = device_get_softc(dev); 760 int error = 0; 761 762 INIT_DEBUGOUT("ixgbe_suspend: begin"); 763 764 IXGBE_CORE_LOCK(adapter); 765 766 error = ixgbe_setup_low_power_mode(adapter); 767 768 /* Save state and power down */ 769 pci_save_state(dev); 770 pci_set_powerstate(dev, PCI_POWERSTATE_D3); 771 772 IXGBE_CORE_UNLOCK(adapter); 773 774 return (error); 775 } 776 777 static int 778 ixgbe_resume(device_t dev) 779 { 780 struct adapter *adapter = device_get_softc(dev); 781 struct ifnet *ifp = adapter->ifp; 782 struct ixgbe_hw *hw = &adapter->hw; 783 u32 wus; 784 785 INIT_DEBUGOUT("ixgbe_resume: begin"); 786 787 IXGBE_CORE_LOCK(adapter); 788 789 pci_set_powerstate(dev, PCI_POWERSTATE_D0); 790 pci_restore_state(dev); 791 792 /* Read & clear WUS register */ 793 wus = IXGBE_READ_REG(hw, IXGBE_WUS); 794 if (wus) 795 device_printf(dev, "Woken up by (WUS): %#010x\n", 796 IXGBE_READ_REG(hw, IXGBE_WUS)); 797 IXGBE_WRITE_REG(hw, IXGBE_WUS, 0xffffffff); 798 /* And clear WUFC until next low-power transition */ 799 IXGBE_WRITE_REG(hw, IXGBE_WUFC, 0); 800 801 /* 802 * Required after D3->D0 transition; 803 * will re-advertise all previous advertised speeds 804 */ 805 if (ifp->if_flags & IFF_UP) 806 ixgbe_init_locked(adapter); 807 808 IXGBE_CORE_UNLOCK(adapter); 809 810 INIT_DEBUGOUT("ixgbe_resume: end"); 811 return (0); 812 } 813 814 815 /********************************************************************* 816 * Ioctl entry point 817 * 818 * ixgbe_ioctl is called when the user wants to configure the 819 * interface. 820 * 821 * return 0 on success, positive on failure 822 **********************************************************************/ 823 824 static int 825 ixgbe_ioctl(struct ifnet * ifp, u_long command, caddr_t data) 826 { 827 struct adapter *adapter = ifp->if_softc; 828 struct ifreq *ifr = (struct ifreq *) data; 829 #if defined(INET) || defined(INET6) 830 struct ifaddr *ifa = (struct ifaddr *)data; 831 #endif 832 int error = 0; 833 bool avoid_reset = FALSE; 834 835 switch (command) { 836 837 case SIOCSIFADDR: 838 #ifdef INET 839 if (ifa->ifa_addr->sa_family == AF_INET) 840 avoid_reset = TRUE; 841 #endif 842 #ifdef INET6 843 if (ifa->ifa_addr->sa_family == AF_INET6) 844 avoid_reset = TRUE; 845 #endif 846 /* 847 ** Calling init results in link renegotiation, 848 ** so we avoid doing it when possible. 849 */ 850 if (avoid_reset) { 851 ifp->if_flags |= IFF_UP; 852 if (!(ifp->if_drv_flags & IFF_DRV_RUNNING)) 853 ixgbe_init(adapter); 854 #if defined(INET) 855 if (!(ifp->if_flags & IFF_NOARP)) 856 arp_ifinit(ifp, ifa); 857 #endif 858 } else 859 error = ether_ioctl(ifp, command, data); 860 break; 861 case SIOCSIFMTU: 862 IOCTL_DEBUGOUT("ioctl: SIOCSIFMTU (Set Interface MTU)"); 863 if (ifr->ifr_mtu > IXGBE_MAX_MTU) { 864 error = EINVAL; 865 } else { 866 IXGBE_CORE_LOCK(adapter); 867 ifp->if_mtu = ifr->ifr_mtu; 868 adapter->max_frame_size = 869 ifp->if_mtu + IXGBE_MTU_HDR; 870 ixgbe_init_locked(adapter); 871 #ifdef PCI_IOV 872 ixgbe_recalculate_max_frame(adapter); 873 #endif 874 IXGBE_CORE_UNLOCK(adapter); 875 } 876 break; 877 case SIOCSIFFLAGS: 878 IOCTL_DEBUGOUT("ioctl: SIOCSIFFLAGS (Set Interface Flags)"); 879 IXGBE_CORE_LOCK(adapter); 880 if (ifp->if_flags & IFF_UP) { 881 if ((ifp->if_drv_flags & IFF_DRV_RUNNING)) { 882 if ((ifp->if_flags ^ adapter->if_flags) & 883 (IFF_PROMISC | IFF_ALLMULTI)) { 884 ixgbe_set_promisc(adapter); 885 } 886 } else 887 ixgbe_init_locked(adapter); 888 } else 889 if (ifp->if_drv_flags & IFF_DRV_RUNNING) 890 ixgbe_stop(adapter); 891 adapter->if_flags = ifp->if_flags; 892 IXGBE_CORE_UNLOCK(adapter); 893 break; 894 case SIOCADDMULTI: 895 case SIOCDELMULTI: 896 IOCTL_DEBUGOUT("ioctl: SIOC(ADD|DEL)MULTI"); 897 if (ifp->if_drv_flags & IFF_DRV_RUNNING) { 898 IXGBE_CORE_LOCK(adapter); 899 ixgbe_disable_intr(adapter); 900 ixgbe_set_multi(adapter); 901 ixgbe_enable_intr(adapter); 902 IXGBE_CORE_UNLOCK(adapter); 903 } 904 break; 905 case SIOCSIFMEDIA: 906 case SIOCGIFMEDIA: 907 IOCTL_DEBUGOUT("ioctl: SIOCxIFMEDIA (Get/Set Interface Media)"); 908 error = ifmedia_ioctl(ifp, ifr, &adapter->media, command); 909 break; 910 case SIOCSIFCAP: 911 { 912 int mask = ifr->ifr_reqcap ^ ifp->if_capenable; 913 IOCTL_DEBUGOUT("ioctl: SIOCSIFCAP (Set Capabilities)"); 914 if (mask & IFCAP_HWCSUM) 915 ifp->if_capenable ^= IFCAP_HWCSUM; 916 if (mask & IFCAP_TSO4) 917 ifp->if_capenable ^= IFCAP_TSO4; 918 if (mask & IFCAP_TSO6) 919 ifp->if_capenable ^= IFCAP_TSO6; 920 if (mask & IFCAP_LRO) 921 ifp->if_capenable ^= IFCAP_LRO; 922 if (mask & IFCAP_VLAN_HWTAGGING) 923 ifp->if_capenable ^= IFCAP_VLAN_HWTAGGING; 924 if (mask & IFCAP_VLAN_HWFILTER) 925 ifp->if_capenable ^= IFCAP_VLAN_HWFILTER; 926 if (mask & IFCAP_VLAN_HWTSO) 927 ifp->if_capenable ^= IFCAP_VLAN_HWTSO; 928 if (ifp->if_drv_flags & IFF_DRV_RUNNING) { 929 IXGBE_CORE_LOCK(adapter); 930 ixgbe_init_locked(adapter); 931 IXGBE_CORE_UNLOCK(adapter); 932 } 933 VLAN_CAPABILITIES(ifp); 934 break; 935 } 936 #if __FreeBSD_version >= 1100036 937 case SIOCGI2C: 938 { 939 struct ixgbe_hw *hw = &adapter->hw; 940 struct ifi2creq i2c; 941 int i; 942 IOCTL_DEBUGOUT("ioctl: SIOCGI2C (Get I2C Data)"); 943 error = copyin(ifr->ifr_data, &i2c, sizeof(i2c)); 944 if (error != 0) 945 break; 946 if (i2c.dev_addr != 0xA0 && i2c.dev_addr != 0xA2) { 947 error = EINVAL; 948 break; 949 } 950 if (i2c.len > sizeof(i2c.data)) { 951 error = EINVAL; 952 break; 953 } 954 955 for (i = 0; i < i2c.len; i++) 956 hw->phy.ops.read_i2c_byte(hw, i2c.offset + i, 957 i2c.dev_addr, &i2c.data[i]); 958 error = copyout(&i2c, ifr->ifr_data, sizeof(i2c)); 959 break; 960 } 961 #endif 962 default: 963 IOCTL_DEBUGOUT1("ioctl: UNKNOWN (0x%X)\n", (int)command); 964 error = ether_ioctl(ifp, command, data); 965 break; 966 } 967 968 return (error); 969 } 970 971 /********************************************************************* 972 * Init entry point 973 * 974 * This routine is used in two ways. It is used by the stack as 975 * init entry point in network interface structure. It is also used 976 * by the driver as a hw/sw initialization routine to get to a 977 * consistent state. 978 * 979 * return 0 on success, positive on failure 980 **********************************************************************/ 981 #define IXGBE_MHADD_MFS_SHIFT 16 982 983 static void 984 ixgbe_init_locked(struct adapter *adapter) 985 { 986 struct ifnet *ifp = adapter->ifp; 987 device_t dev = adapter->dev; 988 struct ixgbe_hw *hw = &adapter->hw; 989 struct tx_ring *txr; 990 struct rx_ring *rxr; 991 u32 txdctl, mhadd; 992 u32 rxdctl, rxctrl; 993 #ifdef PCI_IOV 994 enum ixgbe_iov_mode mode; 995 #endif 996 997 mtx_assert(&adapter->core_mtx, MA_OWNED); 998 INIT_DEBUGOUT("ixgbe_init_locked: begin"); 999 1000 hw->adapter_stopped = FALSE; 1001 ixgbe_stop_adapter(hw); 1002 callout_stop(&adapter->timer); 1003 1004 #ifdef PCI_IOV 1005 mode = ixgbe_get_iov_mode(adapter); 1006 adapter->pool = ixgbe_max_vfs(mode); 1007 /* Queue indices may change with IOV mode */ 1008 for (int i = 0; i < adapter->num_queues; i++) { 1009 adapter->rx_rings[i].me = ixgbe_pf_que_index(mode, i); 1010 adapter->tx_rings[i].me = ixgbe_pf_que_index(mode, i); 1011 } 1012 #endif 1013 /* reprogram the RAR[0] in case user changed it. */ 1014 ixgbe_set_rar(hw, 0, hw->mac.addr, adapter->pool, IXGBE_RAH_AV); 1015 1016 /* Get the latest mac address, User can use a LAA */ 1017 bcopy(IF_LLADDR(ifp), hw->mac.addr, IXGBE_ETH_LENGTH_OF_ADDRESS); 1018 ixgbe_set_rar(hw, 0, hw->mac.addr, adapter->pool, 1); 1019 hw->addr_ctrl.rar_used_count = 1; 1020 1021 /* Set the various hardware offload abilities */ 1022 ifp->if_hwassist = 0; 1023 if (ifp->if_capenable & IFCAP_TSO) 1024 ifp->if_hwassist |= CSUM_TSO; 1025 if (ifp->if_capenable & IFCAP_TXCSUM) { 1026 ifp->if_hwassist |= (CSUM_TCP | CSUM_UDP); 1027 #if __FreeBSD_version >= 800000 1028 if (hw->mac.type != ixgbe_mac_82598EB) 1029 ifp->if_hwassist |= CSUM_SCTP; 1030 #endif 1031 } 1032 1033 /* Prepare transmit descriptors and buffers */ 1034 if (ixgbe_setup_transmit_structures(adapter)) { 1035 device_printf(dev, "Could not setup transmit structures\n"); 1036 ixgbe_stop(adapter); 1037 return; 1038 } 1039 1040 ixgbe_init_hw(hw); 1041 #ifdef PCI_IOV 1042 ixgbe_initialize_iov(adapter); 1043 #endif 1044 ixgbe_initialize_transmit_units(adapter); 1045 1046 /* Setup Multicast table */ 1047 ixgbe_set_multi(adapter); 1048 1049 /* 1050 ** Determine the correct mbuf pool 1051 ** for doing jumbo frames 1052 */ 1053 if (adapter->max_frame_size <= MCLBYTES) 1054 adapter->rx_mbuf_sz = MCLBYTES; 1055 else 1056 adapter->rx_mbuf_sz = MJUMPAGESIZE; 1057 1058 /* Prepare receive descriptors and buffers */ 1059 if (ixgbe_setup_receive_structures(adapter)) { 1060 device_printf(dev, "Could not setup receive structures\n"); 1061 ixgbe_stop(adapter); 1062 return; 1063 } 1064 1065 /* Configure RX settings */ 1066 ixgbe_initialize_receive_units(adapter); 1067 1068 /* Enable SDP & MSIX interrupts based on adapter */ 1069 ixgbe_config_gpie(adapter); 1070 1071 /* Set MTU size */ 1072 if (ifp->if_mtu > ETHERMTU) { 1073 /* aka IXGBE_MAXFRS on 82599 and newer */ 1074 mhadd = IXGBE_READ_REG(hw, IXGBE_MHADD); 1075 mhadd &= ~IXGBE_MHADD_MFS_MASK; 1076 mhadd |= adapter->max_frame_size << IXGBE_MHADD_MFS_SHIFT; 1077 IXGBE_WRITE_REG(hw, IXGBE_MHADD, mhadd); 1078 } 1079 1080 /* Now enable all the queues */ 1081 for (int i = 0; i < adapter->num_queues; i++) { 1082 txr = &adapter->tx_rings[i]; 1083 txdctl = IXGBE_READ_REG(hw, IXGBE_TXDCTL(txr->me)); 1084 txdctl |= IXGBE_TXDCTL_ENABLE; 1085 /* Set WTHRESH to 8, burst writeback */ 1086 txdctl |= (8 << 16); 1087 /* 1088 * When the internal queue falls below PTHRESH (32), 1089 * start prefetching as long as there are at least 1090 * HTHRESH (1) buffers ready. The values are taken 1091 * from the Intel linux driver 3.8.21. 1092 * Prefetching enables tx line rate even with 1 queue. 1093 */ 1094 txdctl |= (32 << 0) | (1 << 8); 1095 IXGBE_WRITE_REG(hw, IXGBE_TXDCTL(txr->me), txdctl); 1096 } 1097 1098 for (int i = 0, j = 0; i < adapter->num_queues; i++) { 1099 rxr = &adapter->rx_rings[i]; 1100 rxdctl = IXGBE_READ_REG(hw, IXGBE_RXDCTL(rxr->me)); 1101 if (hw->mac.type == ixgbe_mac_82598EB) { 1102 /* 1103 ** PTHRESH = 21 1104 ** HTHRESH = 4 1105 ** WTHRESH = 8 1106 */ 1107 rxdctl &= ~0x3FFFFF; 1108 rxdctl |= 0x080420; 1109 } 1110 rxdctl |= IXGBE_RXDCTL_ENABLE; 1111 IXGBE_WRITE_REG(hw, IXGBE_RXDCTL(rxr->me), rxdctl); 1112 for (; j < 10; j++) { 1113 if (IXGBE_READ_REG(hw, IXGBE_RXDCTL(rxr->me)) & 1114 IXGBE_RXDCTL_ENABLE) 1115 break; 1116 else 1117 msec_delay(1); 1118 } 1119 wmb(); 1120 #ifdef DEV_NETMAP 1121 /* 1122 * In netmap mode, we must preserve the buffers made 1123 * available to userspace before the if_init() 1124 * (this is true by default on the TX side, because 1125 * init makes all buffers available to userspace). 1126 * 1127 * netmap_reset() and the device specific routines 1128 * (e.g. ixgbe_setup_receive_rings()) map these 1129 * buffers at the end of the NIC ring, so here we 1130 * must set the RDT (tail) register to make sure 1131 * they are not overwritten. 1132 * 1133 * In this driver the NIC ring starts at RDH = 0, 1134 * RDT points to the last slot available for reception (?), 1135 * so RDT = num_rx_desc - 1 means the whole ring is available. 1136 */ 1137 if (ifp->if_capenable & IFCAP_NETMAP) { 1138 struct netmap_adapter *na = NA(adapter->ifp); 1139 struct netmap_kring *kring = &na->rx_rings[i]; 1140 int t = na->num_rx_desc - 1 - nm_kr_rxspace(kring); 1141 1142 IXGBE_WRITE_REG(hw, IXGBE_RDT(rxr->me), t); 1143 } else 1144 #endif /* DEV_NETMAP */ 1145 IXGBE_WRITE_REG(hw, IXGBE_RDT(rxr->me), adapter->num_rx_desc - 1); 1146 } 1147 1148 /* Enable Receive engine */ 1149 rxctrl = IXGBE_READ_REG(hw, IXGBE_RXCTRL); 1150 if (hw->mac.type == ixgbe_mac_82598EB) 1151 rxctrl |= IXGBE_RXCTRL_DMBYPS; 1152 rxctrl |= IXGBE_RXCTRL_RXEN; 1153 ixgbe_enable_rx_dma(hw, rxctrl); 1154 1155 callout_reset(&adapter->timer, hz, ixgbe_local_timer, adapter); 1156 1157 /* Set up MSI/X routing */ 1158 if (ixgbe_enable_msix) { 1159 ixgbe_configure_ivars(adapter); 1160 /* Set up auto-mask */ 1161 if (hw->mac.type == ixgbe_mac_82598EB) 1162 IXGBE_WRITE_REG(hw, IXGBE_EIAM, IXGBE_EICS_RTX_QUEUE); 1163 else { 1164 IXGBE_WRITE_REG(hw, IXGBE_EIAM_EX(0), 0xFFFFFFFF); 1165 IXGBE_WRITE_REG(hw, IXGBE_EIAM_EX(1), 0xFFFFFFFF); 1166 } 1167 } else { /* Simple settings for Legacy/MSI */ 1168 ixgbe_set_ivar(adapter, 0, 0, 0); 1169 ixgbe_set_ivar(adapter, 0, 0, 1); 1170 IXGBE_WRITE_REG(hw, IXGBE_EIAM, IXGBE_EICS_RTX_QUEUE); 1171 } 1172 1173 #ifdef IXGBE_FDIR 1174 /* Init Flow director */ 1175 if (hw->mac.type != ixgbe_mac_82598EB) { 1176 u32 hdrm = 32 << fdir_pballoc; 1177 1178 hw->mac.ops.setup_rxpba(hw, 0, hdrm, PBA_STRATEGY_EQUAL); 1179 ixgbe_init_fdir_signature_82599(&adapter->hw, fdir_pballoc); 1180 } 1181 #endif 1182 1183 /* 1184 * Check on any SFP devices that 1185 * need to be kick-started 1186 */ 1187 if (hw->phy.type == ixgbe_phy_none) { 1188 int err = hw->phy.ops.identify(hw); 1189 if (err == IXGBE_ERR_SFP_NOT_SUPPORTED) { 1190 device_printf(dev, 1191 "Unsupported SFP+ module type was detected.\n"); 1192 return; 1193 } 1194 } 1195 1196 /* Set moderation on the Link interrupt */ 1197 IXGBE_WRITE_REG(hw, IXGBE_EITR(adapter->vector), IXGBE_LINK_ITR); 1198 1199 /* Configure Energy Efficient Ethernet for supported devices */ 1200 ixgbe_setup_eee(hw, adapter->eee_enabled); 1201 1202 /* Config/Enable Link */ 1203 ixgbe_config_link(adapter); 1204 1205 /* Hardware Packet Buffer & Flow Control setup */ 1206 ixgbe_config_delay_values(adapter); 1207 1208 /* Initialize the FC settings */ 1209 ixgbe_start_hw(hw); 1210 1211 /* Set up VLAN support and filter */ 1212 ixgbe_setup_vlan_hw_support(adapter); 1213 1214 /* Setup DMA Coalescing */ 1215 ixgbe_config_dmac(adapter); 1216 1217 /* And now turn on interrupts */ 1218 ixgbe_enable_intr(adapter); 1219 1220 #ifdef PCI_IOV 1221 /* Enable the use of the MBX by the VF's */ 1222 { 1223 u32 reg = IXGBE_READ_REG(hw, IXGBE_CTRL_EXT); 1224 reg |= IXGBE_CTRL_EXT_PFRSTD; 1225 IXGBE_WRITE_REG(hw, IXGBE_CTRL_EXT, reg); 1226 } 1227 #endif 1228 1229 /* Now inform the stack we're ready */ 1230 ifp->if_drv_flags |= IFF_DRV_RUNNING; 1231 1232 return; 1233 } 1234 1235 static void 1236 ixgbe_init(void *arg) 1237 { 1238 struct adapter *adapter = arg; 1239 1240 IXGBE_CORE_LOCK(adapter); 1241 ixgbe_init_locked(adapter); 1242 IXGBE_CORE_UNLOCK(adapter); 1243 return; 1244 } 1245 1246 static void 1247 ixgbe_config_gpie(struct adapter *adapter) 1248 { 1249 struct ixgbe_hw *hw = &adapter->hw; 1250 u32 gpie; 1251 1252 gpie = IXGBE_READ_REG(hw, IXGBE_GPIE); 1253 1254 /* Fan Failure Interrupt */ 1255 if (hw->device_id == IXGBE_DEV_ID_82598AT) 1256 gpie |= IXGBE_SDP1_GPIEN; 1257 1258 /* 1259 * Module detection (SDP2) 1260 * Media ready (SDP1) 1261 */ 1262 if (hw->mac.type == ixgbe_mac_82599EB) { 1263 gpie |= IXGBE_SDP2_GPIEN; 1264 if (hw->device_id != IXGBE_DEV_ID_82599_QSFP_SF_QP) 1265 gpie |= IXGBE_SDP1_GPIEN; 1266 } 1267 1268 /* 1269 * Thermal Failure Detection (X540) 1270 * Link Detection (X557) 1271 */ 1272 if (hw->mac.type == ixgbe_mac_X540 || 1273 hw->device_id == IXGBE_DEV_ID_X550EM_X_SFP || 1274 hw->device_id == IXGBE_DEV_ID_X550EM_X_10G_T) 1275 gpie |= IXGBE_SDP0_GPIEN_X540; 1276 1277 if (adapter->msix > 1) { 1278 /* Enable Enhanced MSIX mode */ 1279 gpie |= IXGBE_GPIE_MSIX_MODE; 1280 gpie |= IXGBE_GPIE_EIAME | IXGBE_GPIE_PBA_SUPPORT | 1281 IXGBE_GPIE_OCD; 1282 } 1283 1284 IXGBE_WRITE_REG(hw, IXGBE_GPIE, gpie); 1285 return; 1286 } 1287 1288 /* 1289 * Requires adapter->max_frame_size to be set. 1290 */ 1291 static void 1292 ixgbe_config_delay_values(struct adapter *adapter) 1293 { 1294 struct ixgbe_hw *hw = &adapter->hw; 1295 u32 rxpb, frame, size, tmp; 1296 1297 frame = adapter->max_frame_size; 1298 1299 /* Calculate High Water */ 1300 switch (hw->mac.type) { 1301 case ixgbe_mac_X540: 1302 case ixgbe_mac_X550: 1303 case ixgbe_mac_X550EM_x: 1304 tmp = IXGBE_DV_X540(frame, frame); 1305 break; 1306 default: 1307 tmp = IXGBE_DV(frame, frame); 1308 break; 1309 } 1310 size = IXGBE_BT2KB(tmp); 1311 rxpb = IXGBE_READ_REG(hw, IXGBE_RXPBSIZE(0)) >> 10; 1312 hw->fc.high_water[0] = rxpb - size; 1313 1314 /* Now calculate Low Water */ 1315 switch (hw->mac.type) { 1316 case ixgbe_mac_X540: 1317 case ixgbe_mac_X550: 1318 case ixgbe_mac_X550EM_x: 1319 tmp = IXGBE_LOW_DV_X540(frame); 1320 break; 1321 default: 1322 tmp = IXGBE_LOW_DV(frame); 1323 break; 1324 } 1325 hw->fc.low_water[0] = IXGBE_BT2KB(tmp); 1326 1327 hw->fc.requested_mode = adapter->fc; 1328 hw->fc.pause_time = IXGBE_FC_PAUSE; 1329 hw->fc.send_xon = TRUE; 1330 } 1331 1332 /* 1333 ** 1334 ** MSIX Interrupt Handlers and Tasklets 1335 ** 1336 */ 1337 1338 static inline void 1339 ixgbe_enable_queue(struct adapter *adapter, u32 vector) 1340 { 1341 struct ixgbe_hw *hw = &adapter->hw; 1342 u64 queue = (u64)(1 << vector); 1343 u32 mask; 1344 1345 if (hw->mac.type == ixgbe_mac_82598EB) { 1346 mask = (IXGBE_EIMS_RTX_QUEUE & queue); 1347 IXGBE_WRITE_REG(hw, IXGBE_EIMS, mask); 1348 } else { 1349 mask = (queue & 0xFFFFFFFF); 1350 if (mask) 1351 IXGBE_WRITE_REG(hw, IXGBE_EIMS_EX(0), mask); 1352 mask = (queue >> 32); 1353 if (mask) 1354 IXGBE_WRITE_REG(hw, IXGBE_EIMS_EX(1), mask); 1355 } 1356 } 1357 1358 static inline void 1359 ixgbe_disable_queue(struct adapter *adapter, u32 vector) 1360 { 1361 struct ixgbe_hw *hw = &adapter->hw; 1362 u64 queue = (u64)(1 << vector); 1363 u32 mask; 1364 1365 if (hw->mac.type == ixgbe_mac_82598EB) { 1366 mask = (IXGBE_EIMS_RTX_QUEUE & queue); 1367 IXGBE_WRITE_REG(hw, IXGBE_EIMC, mask); 1368 } else { 1369 mask = (queue & 0xFFFFFFFF); 1370 if (mask) 1371 IXGBE_WRITE_REG(hw, IXGBE_EIMC_EX(0), mask); 1372 mask = (queue >> 32); 1373 if (mask) 1374 IXGBE_WRITE_REG(hw, IXGBE_EIMC_EX(1), mask); 1375 } 1376 } 1377 1378 static void 1379 ixgbe_handle_que(void *context, int pending) 1380 { 1381 struct ix_queue *que = context; 1382 struct adapter *adapter = que->adapter; 1383 struct tx_ring *txr = que->txr; 1384 struct ifnet *ifp = adapter->ifp; 1385 1386 if (ifp->if_drv_flags & IFF_DRV_RUNNING) { 1387 ixgbe_rxeof(que); 1388 IXGBE_TX_LOCK(txr); 1389 ixgbe_txeof(txr); 1390 #ifndef IXGBE_LEGACY_TX 1391 if (!drbr_empty(ifp, txr->br)) 1392 ixgbe_mq_start_locked(ifp, txr); 1393 #else 1394 if (!IFQ_DRV_IS_EMPTY(&ifp->if_snd)) 1395 ixgbe_start_locked(txr, ifp); 1396 #endif 1397 IXGBE_TX_UNLOCK(txr); 1398 } 1399 1400 /* Reenable this interrupt */ 1401 if (que->res != NULL) 1402 ixgbe_enable_queue(adapter, que->msix); 1403 else 1404 ixgbe_enable_intr(adapter); 1405 return; 1406 } 1407 1408 1409 /********************************************************************* 1410 * 1411 * Legacy Interrupt Service routine 1412 * 1413 **********************************************************************/ 1414 1415 static void 1416 ixgbe_legacy_irq(void *arg) 1417 { 1418 struct ix_queue *que = arg; 1419 struct adapter *adapter = que->adapter; 1420 struct ixgbe_hw *hw = &adapter->hw; 1421 struct ifnet *ifp = adapter->ifp; 1422 struct tx_ring *txr = adapter->tx_rings; 1423 bool more; 1424 u32 reg_eicr; 1425 1426 1427 reg_eicr = IXGBE_READ_REG(hw, IXGBE_EICR); 1428 1429 ++que->irqs; 1430 if (reg_eicr == 0) { 1431 ixgbe_enable_intr(adapter); 1432 return; 1433 } 1434 1435 more = ixgbe_rxeof(que); 1436 1437 IXGBE_TX_LOCK(txr); 1438 ixgbe_txeof(txr); 1439 #ifdef IXGBE_LEGACY_TX 1440 if (!IFQ_DRV_IS_EMPTY(&ifp->if_snd)) 1441 ixgbe_start_locked(txr, ifp); 1442 #else 1443 if (!drbr_empty(ifp, txr->br)) 1444 ixgbe_mq_start_locked(ifp, txr); 1445 #endif 1446 IXGBE_TX_UNLOCK(txr); 1447 1448 /* Check for fan failure */ 1449 if ((hw->device_id == IXGBE_DEV_ID_82598AT) && 1450 (reg_eicr & IXGBE_EICR_GPI_SDP1)) { 1451 device_printf(adapter->dev, "\nCRITICAL: FAN FAILURE!! " 1452 "REPLACE IMMEDIATELY!!\n"); 1453 IXGBE_WRITE_REG(hw, IXGBE_EIMS, IXGBE_EICR_GPI_SDP1_BY_MAC(hw)); 1454 } 1455 1456 /* Link status change */ 1457 if (reg_eicr & IXGBE_EICR_LSC) 1458 taskqueue_enqueue(adapter->tq, &adapter->link_task); 1459 1460 /* External PHY interrupt */ 1461 if (hw->device_id == IXGBE_DEV_ID_X550EM_X_10G_T && 1462 (reg_eicr & IXGBE_EICR_GPI_SDP0_X540)) 1463 taskqueue_enqueue(adapter->tq, &adapter->phy_task); 1464 1465 if (more) 1466 taskqueue_enqueue(que->tq, &que->que_task); 1467 else 1468 ixgbe_enable_intr(adapter); 1469 return; 1470 } 1471 1472 1473 /********************************************************************* 1474 * 1475 * MSIX Queue Interrupt Service routine 1476 * 1477 **********************************************************************/ 1478 void 1479 ixgbe_msix_que(void *arg) 1480 { 1481 struct ix_queue *que = arg; 1482 struct adapter *adapter = que->adapter; 1483 struct ifnet *ifp = adapter->ifp; 1484 struct tx_ring *txr = que->txr; 1485 struct rx_ring *rxr = que->rxr; 1486 bool more; 1487 u32 newitr = 0; 1488 1489 1490 /* Protect against spurious interrupts */ 1491 if ((ifp->if_drv_flags & IFF_DRV_RUNNING) == 0) 1492 return; 1493 1494 ixgbe_disable_queue(adapter, que->msix); 1495 ++que->irqs; 1496 1497 more = ixgbe_rxeof(que); 1498 1499 IXGBE_TX_LOCK(txr); 1500 ixgbe_txeof(txr); 1501 #ifdef IXGBE_LEGACY_TX 1502 if (!IFQ_DRV_IS_EMPTY(ifp->if_snd)) 1503 ixgbe_start_locked(txr, ifp); 1504 #else 1505 if (!drbr_empty(ifp, txr->br)) 1506 ixgbe_mq_start_locked(ifp, txr); 1507 #endif 1508 IXGBE_TX_UNLOCK(txr); 1509 1510 /* Do AIM now? */ 1511 1512 if (ixgbe_enable_aim == FALSE) 1513 goto no_calc; 1514 /* 1515 ** Do Adaptive Interrupt Moderation: 1516 ** - Write out last calculated setting 1517 ** - Calculate based on average size over 1518 ** the last interval. 1519 */ 1520 if (que->eitr_setting) 1521 IXGBE_WRITE_REG(&adapter->hw, 1522 IXGBE_EITR(que->msix), que->eitr_setting); 1523 1524 que->eitr_setting = 0; 1525 1526 /* Idle, do nothing */ 1527 if ((txr->bytes == 0) && (rxr->bytes == 0)) 1528 goto no_calc; 1529 1530 if ((txr->bytes) && (txr->packets)) 1531 newitr = txr->bytes/txr->packets; 1532 if ((rxr->bytes) && (rxr->packets)) 1533 newitr = max(newitr, 1534 (rxr->bytes / rxr->packets)); 1535 newitr += 24; /* account for hardware frame, crc */ 1536 1537 /* set an upper boundary */ 1538 newitr = min(newitr, 3000); 1539 1540 /* Be nice to the mid range */ 1541 if ((newitr > 300) && (newitr < 1200)) 1542 newitr = (newitr / 3); 1543 else 1544 newitr = (newitr / 2); 1545 1546 if (adapter->hw.mac.type == ixgbe_mac_82598EB) 1547 newitr |= newitr << 16; 1548 else 1549 newitr |= IXGBE_EITR_CNT_WDIS; 1550 1551 /* save for next interrupt */ 1552 que->eitr_setting = newitr; 1553 1554 /* Reset state */ 1555 txr->bytes = 0; 1556 txr->packets = 0; 1557 rxr->bytes = 0; 1558 rxr->packets = 0; 1559 1560 no_calc: 1561 if (more) 1562 taskqueue_enqueue(que->tq, &que->que_task); 1563 else 1564 ixgbe_enable_queue(adapter, que->msix); 1565 return; 1566 } 1567 1568 1569 static void 1570 ixgbe_msix_link(void *arg) 1571 { 1572 struct adapter *adapter = arg; 1573 struct ixgbe_hw *hw = &adapter->hw; 1574 u32 reg_eicr, mod_mask; 1575 1576 ++adapter->link_irq; 1577 1578 /* First get the cause */ 1579 reg_eicr = IXGBE_READ_REG(hw, IXGBE_EICS); 1580 /* Be sure the queue bits are not cleared */ 1581 reg_eicr &= ~IXGBE_EICR_RTX_QUEUE; 1582 /* Clear interrupt with write */ 1583 IXGBE_WRITE_REG(hw, IXGBE_EICR, reg_eicr); 1584 1585 /* Link status change */ 1586 if (reg_eicr & IXGBE_EICR_LSC) 1587 taskqueue_enqueue(adapter->tq, &adapter->link_task); 1588 1589 if (adapter->hw.mac.type != ixgbe_mac_82598EB) { 1590 #ifdef IXGBE_FDIR 1591 if (reg_eicr & IXGBE_EICR_FLOW_DIR) { 1592 /* This is probably overkill :) */ 1593 if (!atomic_cmpset_int(&adapter->fdir_reinit, 0, 1)) 1594 return; 1595 /* Disable the interrupt */ 1596 IXGBE_WRITE_REG(hw, IXGBE_EIMC, IXGBE_EICR_FLOW_DIR); 1597 taskqueue_enqueue(adapter->tq, &adapter->fdir_task); 1598 } else 1599 #endif 1600 if (reg_eicr & IXGBE_EICR_ECC) { 1601 device_printf(adapter->dev, "\nCRITICAL: ECC ERROR!! " 1602 "Please Reboot!!\n"); 1603 IXGBE_WRITE_REG(hw, IXGBE_EICR, IXGBE_EICR_ECC); 1604 } 1605 1606 /* Check for over temp condition */ 1607 if (reg_eicr & IXGBE_EICR_TS) { 1608 device_printf(adapter->dev, "\nCRITICAL: OVER TEMP!! " 1609 "PHY IS SHUT DOWN!!\n"); 1610 device_printf(adapter->dev, "System shutdown required!\n"); 1611 IXGBE_WRITE_REG(hw, IXGBE_EICR, IXGBE_EICR_TS); 1612 } 1613 #ifdef PCI_IOV 1614 if (reg_eicr & IXGBE_EICR_MAILBOX) 1615 taskqueue_enqueue(adapter->tq, &adapter->mbx_task); 1616 #endif 1617 } 1618 1619 /* Pluggable optics-related interrupt */ 1620 if (hw->device_id == IXGBE_DEV_ID_X550EM_X_SFP) 1621 mod_mask = IXGBE_EICR_GPI_SDP0_X540; 1622 else 1623 mod_mask = IXGBE_EICR_GPI_SDP2_BY_MAC(hw); 1624 1625 if (ixgbe_is_sfp(hw)) { 1626 if (reg_eicr & IXGBE_EICR_GPI_SDP1_BY_MAC(hw)) { 1627 IXGBE_WRITE_REG(hw, IXGBE_EICR, IXGBE_EICR_GPI_SDP1_BY_MAC(hw)); 1628 taskqueue_enqueue(adapter->tq, &adapter->msf_task); 1629 } else if (reg_eicr & mod_mask) { 1630 IXGBE_WRITE_REG(hw, IXGBE_EICR, mod_mask); 1631 taskqueue_enqueue(adapter->tq, &adapter->mod_task); 1632 } 1633 } 1634 1635 /* Check for fan failure */ 1636 if ((hw->device_id == IXGBE_DEV_ID_82598AT) && 1637 (reg_eicr & IXGBE_EICR_GPI_SDP1)) { 1638 IXGBE_WRITE_REG(hw, IXGBE_EICR, IXGBE_EICR_GPI_SDP1); 1639 device_printf(adapter->dev, "\nCRITICAL: FAN FAILURE!! " 1640 "REPLACE IMMEDIATELY!!\n"); 1641 } 1642 1643 /* External PHY interrupt */ 1644 if (hw->device_id == IXGBE_DEV_ID_X550EM_X_10G_T && 1645 (reg_eicr & IXGBE_EICR_GPI_SDP0_X540)) { 1646 IXGBE_WRITE_REG(hw, IXGBE_EICR, IXGBE_EICR_GPI_SDP0_X540); 1647 taskqueue_enqueue(adapter->tq, &adapter->phy_task); 1648 } 1649 1650 IXGBE_WRITE_REG(&adapter->hw, IXGBE_EIMS, IXGBE_EIMS_OTHER); 1651 return; 1652 } 1653 1654 /********************************************************************* 1655 * 1656 * Media Ioctl callback 1657 * 1658 * This routine is called whenever the user queries the status of 1659 * the interface using ifconfig. 1660 * 1661 **********************************************************************/ 1662 static void 1663 ixgbe_media_status(struct ifnet * ifp, struct ifmediareq * ifmr) 1664 { 1665 struct adapter *adapter = ifp->if_softc; 1666 struct ixgbe_hw *hw = &adapter->hw; 1667 int layer; 1668 1669 INIT_DEBUGOUT("ixgbe_media_status: begin"); 1670 IXGBE_CORE_LOCK(adapter); 1671 ixgbe_update_link_status(adapter); 1672 1673 ifmr->ifm_status = IFM_AVALID; 1674 ifmr->ifm_active = IFM_ETHER; 1675 1676 if (!adapter->link_active) { 1677 IXGBE_CORE_UNLOCK(adapter); 1678 return; 1679 } 1680 1681 ifmr->ifm_status |= IFM_ACTIVE; 1682 layer = adapter->phy_layer; 1683 1684 if (layer & IXGBE_PHYSICAL_LAYER_10GBASE_T || 1685 layer & IXGBE_PHYSICAL_LAYER_1000BASE_T || 1686 layer & IXGBE_PHYSICAL_LAYER_100BASE_TX) 1687 switch (adapter->link_speed) { 1688 case IXGBE_LINK_SPEED_10GB_FULL: 1689 ifmr->ifm_active |= IFM_10G_T | IFM_FDX; 1690 break; 1691 case IXGBE_LINK_SPEED_1GB_FULL: 1692 ifmr->ifm_active |= IFM_1000_T | IFM_FDX; 1693 break; 1694 case IXGBE_LINK_SPEED_100_FULL: 1695 ifmr->ifm_active |= IFM_100_TX | IFM_FDX; 1696 break; 1697 } 1698 if (layer & IXGBE_PHYSICAL_LAYER_SFP_PLUS_CU || 1699 layer & IXGBE_PHYSICAL_LAYER_SFP_ACTIVE_DA) 1700 switch (adapter->link_speed) { 1701 case IXGBE_LINK_SPEED_10GB_FULL: 1702 ifmr->ifm_active |= IFM_10G_TWINAX | IFM_FDX; 1703 break; 1704 } 1705 if (layer & IXGBE_PHYSICAL_LAYER_10GBASE_LR) 1706 switch (adapter->link_speed) { 1707 case IXGBE_LINK_SPEED_10GB_FULL: 1708 ifmr->ifm_active |= IFM_10G_LR | IFM_FDX; 1709 break; 1710 case IXGBE_LINK_SPEED_1GB_FULL: 1711 ifmr->ifm_active |= IFM_1000_LX | IFM_FDX; 1712 break; 1713 } 1714 if (layer & IXGBE_PHYSICAL_LAYER_10GBASE_LRM) 1715 switch (adapter->link_speed) { 1716 case IXGBE_LINK_SPEED_10GB_FULL: 1717 ifmr->ifm_active |= IFM_10G_LRM | IFM_FDX; 1718 break; 1719 case IXGBE_LINK_SPEED_1GB_FULL: 1720 ifmr->ifm_active |= IFM_1000_LX | IFM_FDX; 1721 break; 1722 } 1723 if (layer & IXGBE_PHYSICAL_LAYER_10GBASE_SR || 1724 layer & IXGBE_PHYSICAL_LAYER_1000BASE_SX) 1725 switch (adapter->link_speed) { 1726 case IXGBE_LINK_SPEED_10GB_FULL: 1727 ifmr->ifm_active |= IFM_10G_SR | IFM_FDX; 1728 break; 1729 case IXGBE_LINK_SPEED_1GB_FULL: 1730 ifmr->ifm_active |= IFM_1000_SX | IFM_FDX; 1731 break; 1732 } 1733 if (layer & IXGBE_PHYSICAL_LAYER_10GBASE_CX4) 1734 switch (adapter->link_speed) { 1735 case IXGBE_LINK_SPEED_10GB_FULL: 1736 ifmr->ifm_active |= IFM_10G_CX4 | IFM_FDX; 1737 break; 1738 } 1739 /* 1740 ** XXX: These need to use the proper media types once 1741 ** they're added. 1742 */ 1743 if (layer & IXGBE_PHYSICAL_LAYER_10GBASE_KR) 1744 switch (adapter->link_speed) { 1745 case IXGBE_LINK_SPEED_10GB_FULL: 1746 ifmr->ifm_active |= IFM_10G_SR | IFM_FDX; 1747 break; 1748 case IXGBE_LINK_SPEED_2_5GB_FULL: 1749 ifmr->ifm_active |= IFM_2500_SX | IFM_FDX; 1750 break; 1751 case IXGBE_LINK_SPEED_1GB_FULL: 1752 ifmr->ifm_active |= IFM_1000_CX | IFM_FDX; 1753 break; 1754 } 1755 else if (layer & IXGBE_PHYSICAL_LAYER_10GBASE_KX4 1756 || layer & IXGBE_PHYSICAL_LAYER_1000BASE_KX) 1757 switch (adapter->link_speed) { 1758 case IXGBE_LINK_SPEED_10GB_FULL: 1759 ifmr->ifm_active |= IFM_10G_CX4 | IFM_FDX; 1760 break; 1761 case IXGBE_LINK_SPEED_2_5GB_FULL: 1762 ifmr->ifm_active |= IFM_2500_SX | IFM_FDX; 1763 break; 1764 case IXGBE_LINK_SPEED_1GB_FULL: 1765 ifmr->ifm_active |= IFM_1000_CX | IFM_FDX; 1766 break; 1767 } 1768 1769 /* If nothing is recognized... */ 1770 if (IFM_SUBTYPE(ifmr->ifm_active) == 0) 1771 ifmr->ifm_active |= IFM_UNKNOWN; 1772 1773 #if __FreeBSD_version >= 900025 1774 /* Display current flow control setting used on link */ 1775 if (hw->fc.current_mode == ixgbe_fc_rx_pause || 1776 hw->fc.current_mode == ixgbe_fc_full) 1777 ifmr->ifm_active |= IFM_ETH_RXPAUSE; 1778 if (hw->fc.current_mode == ixgbe_fc_tx_pause || 1779 hw->fc.current_mode == ixgbe_fc_full) 1780 ifmr->ifm_active |= IFM_ETH_TXPAUSE; 1781 #endif 1782 1783 IXGBE_CORE_UNLOCK(adapter); 1784 1785 return; 1786 } 1787 1788 /********************************************************************* 1789 * 1790 * Media Ioctl callback 1791 * 1792 * This routine is called when the user changes speed/duplex using 1793 * media/mediopt option with ifconfig. 1794 * 1795 **********************************************************************/ 1796 static int 1797 ixgbe_media_change(struct ifnet * ifp) 1798 { 1799 struct adapter *adapter = ifp->if_softc; 1800 struct ifmedia *ifm = &adapter->media; 1801 struct ixgbe_hw *hw = &adapter->hw; 1802 ixgbe_link_speed speed = 0; 1803 1804 INIT_DEBUGOUT("ixgbe_media_change: begin"); 1805 1806 if (IFM_TYPE(ifm->ifm_media) != IFM_ETHER) 1807 return (EINVAL); 1808 1809 if (hw->phy.media_type == ixgbe_media_type_backplane) 1810 return (EPERM); 1811 1812 /* 1813 ** We don't actually need to check against the supported 1814 ** media types of the adapter; ifmedia will take care of 1815 ** that for us. 1816 */ 1817 switch (IFM_SUBTYPE(ifm->ifm_media)) { 1818 case IFM_AUTO: 1819 case IFM_10G_T: 1820 speed |= IXGBE_LINK_SPEED_100_FULL; 1821 case IFM_10G_LRM: 1822 case IFM_10G_SR: /* KR, too */ 1823 case IFM_10G_LR: 1824 case IFM_10G_CX4: /* KX4 */ 1825 speed |= IXGBE_LINK_SPEED_1GB_FULL; 1826 case IFM_10G_TWINAX: 1827 speed |= IXGBE_LINK_SPEED_10GB_FULL; 1828 break; 1829 case IFM_1000_T: 1830 speed |= IXGBE_LINK_SPEED_100_FULL; 1831 case IFM_1000_LX: 1832 case IFM_1000_SX: 1833 case IFM_1000_CX: /* KX */ 1834 speed |= IXGBE_LINK_SPEED_1GB_FULL; 1835 break; 1836 case IFM_100_TX: 1837 speed |= IXGBE_LINK_SPEED_100_FULL; 1838 break; 1839 default: 1840 goto invalid; 1841 } 1842 1843 hw->mac.autotry_restart = TRUE; 1844 hw->mac.ops.setup_link(hw, speed, TRUE); 1845 adapter->advertise = 1846 ((speed & IXGBE_LINK_SPEED_10GB_FULL) << 2) | 1847 ((speed & IXGBE_LINK_SPEED_1GB_FULL) << 1) | 1848 ((speed & IXGBE_LINK_SPEED_100_FULL) << 0); 1849 1850 return (0); 1851 1852 invalid: 1853 device_printf(adapter->dev, "Invalid media type!\n"); 1854 return (EINVAL); 1855 } 1856 1857 static void 1858 ixgbe_set_promisc(struct adapter *adapter) 1859 { 1860 u_int32_t reg_rctl; 1861 struct ifnet *ifp = adapter->ifp; 1862 int mcnt = 0; 1863 1864 reg_rctl = IXGBE_READ_REG(&adapter->hw, IXGBE_FCTRL); 1865 reg_rctl &= (~IXGBE_FCTRL_UPE); 1866 if (ifp->if_flags & IFF_ALLMULTI) 1867 mcnt = MAX_NUM_MULTICAST_ADDRESSES; 1868 else { 1869 struct ifmultiaddr *ifma; 1870 #if __FreeBSD_version < 800000 1871 IF_ADDR_LOCK(ifp); 1872 #else 1873 if_maddr_rlock(ifp); 1874 #endif 1875 TAILQ_FOREACH(ifma, &ifp->if_multiaddrs, ifma_link) { 1876 if (ifma->ifma_addr->sa_family != AF_LINK) 1877 continue; 1878 if (mcnt == MAX_NUM_MULTICAST_ADDRESSES) 1879 break; 1880 mcnt++; 1881 } 1882 #if __FreeBSD_version < 800000 1883 IF_ADDR_UNLOCK(ifp); 1884 #else 1885 if_maddr_runlock(ifp); 1886 #endif 1887 } 1888 if (mcnt < MAX_NUM_MULTICAST_ADDRESSES) 1889 reg_rctl &= (~IXGBE_FCTRL_MPE); 1890 IXGBE_WRITE_REG(&adapter->hw, IXGBE_FCTRL, reg_rctl); 1891 1892 if (ifp->if_flags & IFF_PROMISC) { 1893 reg_rctl |= (IXGBE_FCTRL_UPE | IXGBE_FCTRL_MPE); 1894 IXGBE_WRITE_REG(&adapter->hw, IXGBE_FCTRL, reg_rctl); 1895 } else if (ifp->if_flags & IFF_ALLMULTI) { 1896 reg_rctl |= IXGBE_FCTRL_MPE; 1897 reg_rctl &= ~IXGBE_FCTRL_UPE; 1898 IXGBE_WRITE_REG(&adapter->hw, IXGBE_FCTRL, reg_rctl); 1899 } 1900 return; 1901 } 1902 1903 1904 /********************************************************************* 1905 * Multicast Update 1906 * 1907 * This routine is called whenever multicast address list is updated. 1908 * 1909 **********************************************************************/ 1910 #define IXGBE_RAR_ENTRIES 16 1911 1912 static void 1913 ixgbe_set_multi(struct adapter *adapter) 1914 { 1915 u32 fctrl; 1916 u8 *update_ptr; 1917 struct ifmultiaddr *ifma; 1918 struct ixgbe_mc_addr *mta; 1919 int mcnt = 0; 1920 struct ifnet *ifp = adapter->ifp; 1921 1922 IOCTL_DEBUGOUT("ixgbe_set_multi: begin"); 1923 1924 mta = adapter->mta; 1925 bzero(mta, sizeof(*mta) * MAX_NUM_MULTICAST_ADDRESSES); 1926 1927 #if __FreeBSD_version < 800000 1928 IF_ADDR_LOCK(ifp); 1929 #else 1930 if_maddr_rlock(ifp); 1931 #endif 1932 TAILQ_FOREACH(ifma, &ifp->if_multiaddrs, ifma_link) { 1933 if (ifma->ifma_addr->sa_family != AF_LINK) 1934 continue; 1935 if (mcnt == MAX_NUM_MULTICAST_ADDRESSES) 1936 break; 1937 bcopy(LLADDR((struct sockaddr_dl *) ifma->ifma_addr), 1938 mta[mcnt].addr, IXGBE_ETH_LENGTH_OF_ADDRESS); 1939 mta[mcnt].vmdq = adapter->pool; 1940 mcnt++; 1941 } 1942 #if __FreeBSD_version < 800000 1943 IF_ADDR_UNLOCK(ifp); 1944 #else 1945 if_maddr_runlock(ifp); 1946 #endif 1947 1948 fctrl = IXGBE_READ_REG(&adapter->hw, IXGBE_FCTRL); 1949 fctrl |= (IXGBE_FCTRL_UPE | IXGBE_FCTRL_MPE); 1950 if (ifp->if_flags & IFF_PROMISC) 1951 fctrl |= (IXGBE_FCTRL_UPE | IXGBE_FCTRL_MPE); 1952 else if (mcnt >= MAX_NUM_MULTICAST_ADDRESSES || 1953 ifp->if_flags & IFF_ALLMULTI) { 1954 fctrl |= IXGBE_FCTRL_MPE; 1955 fctrl &= ~IXGBE_FCTRL_UPE; 1956 } else 1957 fctrl &= ~(IXGBE_FCTRL_UPE | IXGBE_FCTRL_MPE); 1958 1959 IXGBE_WRITE_REG(&adapter->hw, IXGBE_FCTRL, fctrl); 1960 1961 if (mcnt < MAX_NUM_MULTICAST_ADDRESSES) { 1962 update_ptr = (u8 *)mta; 1963 ixgbe_update_mc_addr_list(&adapter->hw, 1964 update_ptr, mcnt, ixgbe_mc_array_itr, TRUE); 1965 } 1966 1967 return; 1968 } 1969 1970 /* 1971 * This is an iterator function now needed by the multicast 1972 * shared code. It simply feeds the shared code routine the 1973 * addresses in the array of ixgbe_set_multi() one by one. 1974 */ 1975 static u8 * 1976 ixgbe_mc_array_itr(struct ixgbe_hw *hw, u8 **update_ptr, u32 *vmdq) 1977 { 1978 struct ixgbe_mc_addr *mta; 1979 1980 mta = (struct ixgbe_mc_addr *)*update_ptr; 1981 *vmdq = mta->vmdq; 1982 1983 *update_ptr = (u8*)(mta + 1);; 1984 return (mta->addr); 1985 } 1986 1987 1988 /********************************************************************* 1989 * Timer routine 1990 * 1991 * This routine checks for link status,updates statistics, 1992 * and runs the watchdog check. 1993 * 1994 **********************************************************************/ 1995 1996 static void 1997 ixgbe_local_timer(void *arg) 1998 { 1999 struct adapter *adapter = arg; 2000 device_t dev = adapter->dev; 2001 struct ix_queue *que = adapter->queues; 2002 u64 queues = 0; 2003 int hung = 0; 2004 2005 mtx_assert(&adapter->core_mtx, MA_OWNED); 2006 2007 /* Check for pluggable optics */ 2008 if (adapter->sfp_probe) 2009 if (!ixgbe_sfp_probe(adapter)) 2010 goto out; /* Nothing to do */ 2011 2012 ixgbe_update_link_status(adapter); 2013 ixgbe_update_stats_counters(adapter); 2014 2015 /* 2016 ** Check the TX queues status 2017 ** - mark hung queues so we don't schedule on them 2018 ** - watchdog only if all queues show hung 2019 */ 2020 for (int i = 0; i < adapter->num_queues; i++, que++) { 2021 /* Keep track of queues with work for soft irq */ 2022 if (que->txr->busy) 2023 queues |= ((u64)1 << que->me); 2024 /* 2025 ** Each time txeof runs without cleaning, but there 2026 ** are uncleaned descriptors it increments busy. If 2027 ** we get to the MAX we declare it hung. 2028 */ 2029 if (que->busy == IXGBE_QUEUE_HUNG) { 2030 ++hung; 2031 /* Mark the queue as inactive */ 2032 adapter->active_queues &= ~((u64)1 << que->me); 2033 continue; 2034 } else { 2035 /* Check if we've come back from hung */ 2036 if ((adapter->active_queues & ((u64)1 << que->me)) == 0) 2037 adapter->active_queues |= ((u64)1 << que->me); 2038 } 2039 if (que->busy >= IXGBE_MAX_TX_BUSY) { 2040 device_printf(dev,"Warning queue %d " 2041 "appears to be hung!\n", i); 2042 que->txr->busy = IXGBE_QUEUE_HUNG; 2043 ++hung; 2044 } 2045 2046 } 2047 2048 /* Only truly watchdog if all queues show hung */ 2049 if (hung == adapter->num_queues) 2050 goto watchdog; 2051 else if (queues != 0) { /* Force an IRQ on queues with work */ 2052 ixgbe_rearm_queues(adapter, queues); 2053 } 2054 2055 out: 2056 callout_reset(&adapter->timer, hz, ixgbe_local_timer, adapter); 2057 return; 2058 2059 watchdog: 2060 device_printf(adapter->dev, "Watchdog timeout -- resetting\n"); 2061 adapter->ifp->if_drv_flags &= ~IFF_DRV_RUNNING; 2062 adapter->watchdog_events++; 2063 ixgbe_init_locked(adapter); 2064 } 2065 2066 2067 /* 2068 ** Note: this routine updates the OS on the link state 2069 ** the real check of the hardware only happens with 2070 ** a link interrupt. 2071 */ 2072 static void 2073 ixgbe_update_link_status(struct adapter *adapter) 2074 { 2075 struct ifnet *ifp = adapter->ifp; 2076 device_t dev = adapter->dev; 2077 2078 if (adapter->link_up){ 2079 if (adapter->link_active == FALSE) { 2080 if (bootverbose) 2081 device_printf(dev,"Link is up %d Gbps %s \n", 2082 ((adapter->link_speed == 128)? 10:1), 2083 "Full Duplex"); 2084 adapter->link_active = TRUE; 2085 /* Update any Flow Control changes */ 2086 ixgbe_fc_enable(&adapter->hw); 2087 /* Update DMA coalescing config */ 2088 ixgbe_config_dmac(adapter); 2089 if_link_state_change(ifp, LINK_STATE_UP); 2090 #ifdef PCI_IOV 2091 ixgbe_ping_all_vfs(adapter); 2092 #endif 2093 } 2094 } else { /* Link down */ 2095 if (adapter->link_active == TRUE) { 2096 if (bootverbose) 2097 device_printf(dev,"Link is Down\n"); 2098 if_link_state_change(ifp, LINK_STATE_DOWN); 2099 adapter->link_active = FALSE; 2100 #ifdef PCI_IOV 2101 ixgbe_ping_all_vfs(adapter); 2102 #endif 2103 } 2104 } 2105 2106 return; 2107 } 2108 2109 2110 /********************************************************************* 2111 * 2112 * This routine disables all traffic on the adapter by issuing a 2113 * global reset on the MAC and deallocates TX/RX buffers. 2114 * 2115 **********************************************************************/ 2116 2117 static void 2118 ixgbe_stop(void *arg) 2119 { 2120 struct ifnet *ifp; 2121 struct adapter *adapter = arg; 2122 struct ixgbe_hw *hw = &adapter->hw; 2123 ifp = adapter->ifp; 2124 2125 mtx_assert(&adapter->core_mtx, MA_OWNED); 2126 2127 INIT_DEBUGOUT("ixgbe_stop: begin\n"); 2128 ixgbe_disable_intr(adapter); 2129 callout_stop(&adapter->timer); 2130 2131 /* Let the stack know...*/ 2132 ifp->if_drv_flags &= ~IFF_DRV_RUNNING; 2133 2134 ixgbe_reset_hw(hw); 2135 hw->adapter_stopped = FALSE; 2136 ixgbe_stop_adapter(hw); 2137 if (hw->mac.type == ixgbe_mac_82599EB) 2138 ixgbe_stop_mac_link_on_d3_82599(hw); 2139 /* Turn off the laser - noop with no optics */ 2140 ixgbe_disable_tx_laser(hw); 2141 2142 /* Update the stack */ 2143 adapter->link_up = FALSE; 2144 ixgbe_update_link_status(adapter); 2145 2146 /* reprogram the RAR[0] in case user changed it. */ 2147 ixgbe_set_rar(&adapter->hw, 0, adapter->hw.mac.addr, 0, IXGBE_RAH_AV); 2148 2149 return; 2150 } 2151 2152 2153 /********************************************************************* 2154 * 2155 * Determine hardware revision. 2156 * 2157 **********************************************************************/ 2158 static void 2159 ixgbe_identify_hardware(struct adapter *adapter) 2160 { 2161 device_t dev = adapter->dev; 2162 struct ixgbe_hw *hw = &adapter->hw; 2163 2164 /* Save off the information about this board */ 2165 hw->vendor_id = pci_get_vendor(dev); 2166 hw->device_id = pci_get_device(dev); 2167 hw->revision_id = pci_read_config(dev, PCIR_REVID, 1); 2168 hw->subsystem_vendor_id = 2169 pci_read_config(dev, PCIR_SUBVEND_0, 2); 2170 hw->subsystem_device_id = 2171 pci_read_config(dev, PCIR_SUBDEV_0, 2); 2172 2173 /* 2174 ** Make sure BUSMASTER is set 2175 */ 2176 pci_enable_busmaster(dev); 2177 2178 /* We need this here to set the num_segs below */ 2179 ixgbe_set_mac_type(hw); 2180 2181 /* Pick up the 82599 settings */ 2182 if (hw->mac.type != ixgbe_mac_82598EB) { 2183 hw->phy.smart_speed = ixgbe_smart_speed; 2184 adapter->num_segs = IXGBE_82599_SCATTER; 2185 } else 2186 adapter->num_segs = IXGBE_82598_SCATTER; 2187 2188 return; 2189 } 2190 2191 /********************************************************************* 2192 * 2193 * Determine optic type 2194 * 2195 **********************************************************************/ 2196 static void 2197 ixgbe_setup_optics(struct adapter *adapter) 2198 { 2199 struct ixgbe_hw *hw = &adapter->hw; 2200 int layer; 2201 2202 layer = adapter->phy_layer = ixgbe_get_supported_physical_layer(hw); 2203 2204 if (layer & IXGBE_PHYSICAL_LAYER_10GBASE_T) { 2205 adapter->optics = IFM_10G_T; 2206 return; 2207 } 2208 2209 if (layer & IXGBE_PHYSICAL_LAYER_1000BASE_T) { 2210 adapter->optics = IFM_1000_T; 2211 return; 2212 } 2213 2214 if (layer & IXGBE_PHYSICAL_LAYER_1000BASE_SX) { 2215 adapter->optics = IFM_1000_SX; 2216 return; 2217 } 2218 2219 if (layer & (IXGBE_PHYSICAL_LAYER_10GBASE_LR | 2220 IXGBE_PHYSICAL_LAYER_10GBASE_LRM)) { 2221 adapter->optics = IFM_10G_LR; 2222 return; 2223 } 2224 2225 if (layer & IXGBE_PHYSICAL_LAYER_10GBASE_SR) { 2226 adapter->optics = IFM_10G_SR; 2227 return; 2228 } 2229 2230 if (layer & IXGBE_PHYSICAL_LAYER_SFP_PLUS_CU) { 2231 adapter->optics = IFM_10G_TWINAX; 2232 return; 2233 } 2234 2235 if (layer & (IXGBE_PHYSICAL_LAYER_10GBASE_KX4 | 2236 IXGBE_PHYSICAL_LAYER_10GBASE_CX4)) { 2237 adapter->optics = IFM_10G_CX4; 2238 return; 2239 } 2240 2241 /* If we get here just set the default */ 2242 adapter->optics = IFM_ETHER | IFM_AUTO; 2243 return; 2244 } 2245 2246 /********************************************************************* 2247 * 2248 * Setup the Legacy or MSI Interrupt handler 2249 * 2250 **********************************************************************/ 2251 static int 2252 ixgbe_allocate_legacy(struct adapter *adapter) 2253 { 2254 device_t dev = adapter->dev; 2255 struct ix_queue *que = adapter->queues; 2256 #ifndef IXGBE_LEGACY_TX 2257 struct tx_ring *txr = adapter->tx_rings; 2258 #endif 2259 int error, rid = 0; 2260 2261 /* MSI RID at 1 */ 2262 if (adapter->msix == 1) 2263 rid = 1; 2264 2265 /* We allocate a single interrupt resource */ 2266 adapter->res = bus_alloc_resource_any(dev, 2267 SYS_RES_IRQ, &rid, RF_SHAREABLE | RF_ACTIVE); 2268 if (adapter->res == NULL) { 2269 device_printf(dev, "Unable to allocate bus resource: " 2270 "interrupt\n"); 2271 return (ENXIO); 2272 } 2273 2274 /* 2275 * Try allocating a fast interrupt and the associated deferred 2276 * processing contexts. 2277 */ 2278 #ifndef IXGBE_LEGACY_TX 2279 TASK_INIT(&txr->txq_task, 0, ixgbe_deferred_mq_start, txr); 2280 #endif 2281 TASK_INIT(&que->que_task, 0, ixgbe_handle_que, que); 2282 que->tq = taskqueue_create_fast("ixgbe_que", M_NOWAIT, 2283 taskqueue_thread_enqueue, &que->tq); 2284 taskqueue_start_threads(&que->tq, 1, PI_NET, "%s ixq", 2285 device_get_nameunit(adapter->dev)); 2286 2287 /* Tasklets for Link, SFP and Multispeed Fiber */ 2288 TASK_INIT(&adapter->link_task, 0, ixgbe_handle_link, adapter); 2289 TASK_INIT(&adapter->mod_task, 0, ixgbe_handle_mod, adapter); 2290 TASK_INIT(&adapter->msf_task, 0, ixgbe_handle_msf, adapter); 2291 TASK_INIT(&adapter->phy_task, 0, ixgbe_handle_phy, adapter); 2292 #ifdef IXGBE_FDIR 2293 TASK_INIT(&adapter->fdir_task, 0, ixgbe_reinit_fdir, adapter); 2294 #endif 2295 adapter->tq = taskqueue_create_fast("ixgbe_link", M_NOWAIT, 2296 taskqueue_thread_enqueue, &adapter->tq); 2297 taskqueue_start_threads(&adapter->tq, 1, PI_NET, "%s linkq", 2298 device_get_nameunit(adapter->dev)); 2299 2300 if ((error = bus_setup_intr(dev, adapter->res, 2301 INTR_TYPE_NET | INTR_MPSAFE, NULL, ixgbe_legacy_irq, 2302 que, &adapter->tag)) != 0) { 2303 device_printf(dev, "Failed to register fast interrupt " 2304 "handler: %d\n", error); 2305 taskqueue_free(que->tq); 2306 taskqueue_free(adapter->tq); 2307 que->tq = NULL; 2308 adapter->tq = NULL; 2309 return (error); 2310 } 2311 /* For simplicity in the handlers */ 2312 adapter->active_queues = IXGBE_EIMS_ENABLE_MASK; 2313 2314 return (0); 2315 } 2316 2317 2318 /********************************************************************* 2319 * 2320 * Setup MSIX Interrupt resources and handlers 2321 * 2322 **********************************************************************/ 2323 static int 2324 ixgbe_allocate_msix(struct adapter *adapter) 2325 { 2326 device_t dev = adapter->dev; 2327 struct ix_queue *que = adapter->queues; 2328 struct tx_ring *txr = adapter->tx_rings; 2329 int error, rid, vector = 0; 2330 int cpu_id = 0; 2331 #ifdef RSS 2332 cpuset_t cpu_mask; 2333 #endif 2334 2335 #ifdef RSS 2336 /* 2337 * If we're doing RSS, the number of queues needs to 2338 * match the number of RSS buckets that are configured. 2339 * 2340 * + If there's more queues than RSS buckets, we'll end 2341 * up with queues that get no traffic. 2342 * 2343 * + If there's more RSS buckets than queues, we'll end 2344 * up having multiple RSS buckets map to the same queue, 2345 * so there'll be some contention. 2346 */ 2347 if (adapter->num_queues != rss_getnumbuckets()) { 2348 device_printf(dev, 2349 "%s: number of queues (%d) != number of RSS buckets (%d)" 2350 "; performance will be impacted.\n", 2351 __func__, 2352 adapter->num_queues, 2353 rss_getnumbuckets()); 2354 } 2355 #endif 2356 2357 for (int i = 0; i < adapter->num_queues; i++, vector++, que++, txr++) { 2358 rid = vector + 1; 2359 que->res = bus_alloc_resource_any(dev, SYS_RES_IRQ, &rid, 2360 RF_SHAREABLE | RF_ACTIVE); 2361 if (que->res == NULL) { 2362 device_printf(dev,"Unable to allocate" 2363 " bus resource: que interrupt [%d]\n", vector); 2364 return (ENXIO); 2365 } 2366 /* Set the handler function */ 2367 error = bus_setup_intr(dev, que->res, 2368 INTR_TYPE_NET | INTR_MPSAFE, NULL, 2369 ixgbe_msix_que, que, &que->tag); 2370 if (error) { 2371 que->res = NULL; 2372 device_printf(dev, "Failed to register QUE handler"); 2373 return (error); 2374 } 2375 #if __FreeBSD_version >= 800504 2376 bus_describe_intr(dev, que->res, que->tag, "que %d", i); 2377 #endif 2378 que->msix = vector; 2379 adapter->active_queues |= (u64)(1 << que->msix); 2380 #ifdef RSS 2381 /* 2382 * The queue ID is used as the RSS layer bucket ID. 2383 * We look up the queue ID -> RSS CPU ID and select 2384 * that. 2385 */ 2386 cpu_id = rss_getcpu(i % rss_getnumbuckets()); 2387 #else 2388 /* 2389 * Bind the msix vector, and thus the 2390 * rings to the corresponding cpu. 2391 * 2392 * This just happens to match the default RSS round-robin 2393 * bucket -> queue -> CPU allocation. 2394 */ 2395 if (adapter->num_queues > 1) 2396 cpu_id = i; 2397 #endif 2398 if (adapter->num_queues > 1) 2399 bus_bind_intr(dev, que->res, cpu_id); 2400 #ifdef IXGBE_DEBUG 2401 #ifdef RSS 2402 device_printf(dev, 2403 "Bound RSS bucket %d to CPU %d\n", 2404 i, cpu_id); 2405 #else 2406 device_printf(dev, 2407 "Bound queue %d to cpu %d\n", 2408 i, cpu_id); 2409 #endif 2410 #endif /* IXGBE_DEBUG */ 2411 2412 2413 #ifndef IXGBE_LEGACY_TX 2414 TASK_INIT(&txr->txq_task, 0, ixgbe_deferred_mq_start, txr); 2415 #endif 2416 TASK_INIT(&que->que_task, 0, ixgbe_handle_que, que); 2417 que->tq = taskqueue_create_fast("ixgbe_que", M_NOWAIT, 2418 taskqueue_thread_enqueue, &que->tq); 2419 #ifdef RSS 2420 CPU_SETOF(cpu_id, &cpu_mask); 2421 taskqueue_start_threads_cpuset(&que->tq, 1, PI_NET, 2422 &cpu_mask, 2423 "%s (bucket %d)", 2424 device_get_nameunit(adapter->dev), 2425 cpu_id); 2426 #else 2427 taskqueue_start_threads(&que->tq, 1, PI_NET, "%s que", 2428 device_get_nameunit(adapter->dev)); 2429 #endif 2430 } 2431 2432 /* and Link */ 2433 rid = vector + 1; 2434 adapter->res = bus_alloc_resource_any(dev, 2435 SYS_RES_IRQ, &rid, RF_SHAREABLE | RF_ACTIVE); 2436 if (!adapter->res) { 2437 device_printf(dev,"Unable to allocate" 2438 " bus resource: Link interrupt [%d]\n", rid); 2439 return (ENXIO); 2440 } 2441 /* Set the link handler function */ 2442 error = bus_setup_intr(dev, adapter->res, 2443 INTR_TYPE_NET | INTR_MPSAFE, NULL, 2444 ixgbe_msix_link, adapter, &adapter->tag); 2445 if (error) { 2446 adapter->res = NULL; 2447 device_printf(dev, "Failed to register LINK handler"); 2448 return (error); 2449 } 2450 #if __FreeBSD_version >= 800504 2451 bus_describe_intr(dev, adapter->res, adapter->tag, "link"); 2452 #endif 2453 adapter->vector = vector; 2454 /* Tasklets for Link, SFP and Multispeed Fiber */ 2455 TASK_INIT(&adapter->link_task, 0, ixgbe_handle_link, adapter); 2456 TASK_INIT(&adapter->mod_task, 0, ixgbe_handle_mod, adapter); 2457 TASK_INIT(&adapter->msf_task, 0, ixgbe_handle_msf, adapter); 2458 #ifdef PCI_IOV 2459 TASK_INIT(&adapter->mbx_task, 0, ixgbe_handle_mbx, adapter); 2460 #endif 2461 TASK_INIT(&adapter->phy_task, 0, ixgbe_handle_phy, adapter); 2462 #ifdef IXGBE_FDIR 2463 TASK_INIT(&adapter->fdir_task, 0, ixgbe_reinit_fdir, adapter); 2464 #endif 2465 adapter->tq = taskqueue_create_fast("ixgbe_link", M_NOWAIT, 2466 taskqueue_thread_enqueue, &adapter->tq); 2467 taskqueue_start_threads(&adapter->tq, 1, PI_NET, "%s linkq", 2468 device_get_nameunit(adapter->dev)); 2469 2470 return (0); 2471 } 2472 2473 /* 2474 * Setup Either MSI/X or MSI 2475 */ 2476 static int 2477 ixgbe_setup_msix(struct adapter *adapter) 2478 { 2479 device_t dev = adapter->dev; 2480 int rid, want, queues, msgs; 2481 2482 /* Override by tuneable */ 2483 if (ixgbe_enable_msix == 0) 2484 goto msi; 2485 2486 /* First try MSI/X */ 2487 msgs = pci_msix_count(dev); 2488 if (msgs == 0) 2489 goto msi; 2490 rid = PCIR_BAR(MSIX_82598_BAR); 2491 adapter->msix_mem = bus_alloc_resource_any(dev, 2492 SYS_RES_MEMORY, &rid, RF_ACTIVE); 2493 if (adapter->msix_mem == NULL) { 2494 rid += 4; /* 82599 maps in higher BAR */ 2495 adapter->msix_mem = bus_alloc_resource_any(dev, 2496 SYS_RES_MEMORY, &rid, RF_ACTIVE); 2497 } 2498 if (adapter->msix_mem == NULL) { 2499 /* May not be enabled */ 2500 device_printf(adapter->dev, 2501 "Unable to map MSIX table \n"); 2502 goto msi; 2503 } 2504 2505 /* Figure out a reasonable auto config value */ 2506 queues = (mp_ncpus > (msgs-1)) ? (msgs-1) : mp_ncpus; 2507 2508 #ifdef RSS 2509 /* If we're doing RSS, clamp at the number of RSS buckets */ 2510 if (queues > rss_getnumbuckets()) 2511 queues = rss_getnumbuckets(); 2512 #endif 2513 2514 if (ixgbe_num_queues != 0) 2515 queues = ixgbe_num_queues; 2516 2517 /* reflect correct sysctl value */ 2518 ixgbe_num_queues = queues; 2519 2520 /* 2521 ** Want one vector (RX/TX pair) per queue 2522 ** plus an additional for Link. 2523 */ 2524 want = queues + 1; 2525 if (msgs >= want) 2526 msgs = want; 2527 else { 2528 device_printf(adapter->dev, 2529 "MSIX Configuration Problem, " 2530 "%d vectors but %d queues wanted!\n", 2531 msgs, want); 2532 goto msi; 2533 } 2534 if ((pci_alloc_msix(dev, &msgs) == 0) && (msgs == want)) { 2535 device_printf(adapter->dev, 2536 "Using MSIX interrupts with %d vectors\n", msgs); 2537 adapter->num_queues = queues; 2538 return (msgs); 2539 } 2540 /* 2541 ** If MSIX alloc failed or provided us with 2542 ** less than needed, free and fall through to MSI 2543 */ 2544 pci_release_msi(dev); 2545 2546 msi: 2547 if (adapter->msix_mem != NULL) { 2548 bus_release_resource(dev, SYS_RES_MEMORY, 2549 rid, adapter->msix_mem); 2550 adapter->msix_mem = NULL; 2551 } 2552 msgs = 1; 2553 if (pci_alloc_msi(dev, &msgs) == 0) { 2554 device_printf(adapter->dev,"Using an MSI interrupt\n"); 2555 return (msgs); 2556 } 2557 device_printf(adapter->dev,"Using a Legacy interrupt\n"); 2558 return (0); 2559 } 2560 2561 2562 static int 2563 ixgbe_allocate_pci_resources(struct adapter *adapter) 2564 { 2565 int rid; 2566 device_t dev = adapter->dev; 2567 2568 rid = PCIR_BAR(0); 2569 adapter->pci_mem = bus_alloc_resource_any(dev, SYS_RES_MEMORY, 2570 &rid, RF_ACTIVE); 2571 2572 if (!(adapter->pci_mem)) { 2573 device_printf(dev,"Unable to allocate bus resource: memory\n"); 2574 return (ENXIO); 2575 } 2576 2577 adapter->osdep.mem_bus_space_tag = 2578 rman_get_bustag(adapter->pci_mem); 2579 adapter->osdep.mem_bus_space_handle = 2580 rman_get_bushandle(adapter->pci_mem); 2581 adapter->hw.hw_addr = (u8 *) &adapter->osdep.mem_bus_space_handle; 2582 2583 /* Legacy defaults */ 2584 adapter->num_queues = 1; 2585 adapter->hw.back = &adapter->osdep; 2586 2587 /* 2588 ** Now setup MSI or MSI/X, should 2589 ** return us the number of supported 2590 ** vectors. (Will be 1 for MSI) 2591 */ 2592 adapter->msix = ixgbe_setup_msix(adapter); 2593 return (0); 2594 } 2595 2596 static void 2597 ixgbe_free_pci_resources(struct adapter * adapter) 2598 { 2599 struct ix_queue *que = adapter->queues; 2600 device_t dev = adapter->dev; 2601 int rid, memrid; 2602 2603 if (adapter->hw.mac.type == ixgbe_mac_82598EB) 2604 memrid = PCIR_BAR(MSIX_82598_BAR); 2605 else 2606 memrid = PCIR_BAR(MSIX_82599_BAR); 2607 2608 /* 2609 ** There is a slight possibility of a failure mode 2610 ** in attach that will result in entering this function 2611 ** before interrupt resources have been initialized, and 2612 ** in that case we do not want to execute the loops below 2613 ** We can detect this reliably by the state of the adapter 2614 ** res pointer. 2615 */ 2616 if (adapter->res == NULL) 2617 goto mem; 2618 2619 /* 2620 ** Release all msix queue resources: 2621 */ 2622 for (int i = 0; i < adapter->num_queues; i++, que++) { 2623 rid = que->msix + 1; 2624 if (que->tag != NULL) { 2625 bus_teardown_intr(dev, que->res, que->tag); 2626 que->tag = NULL; 2627 } 2628 if (que->res != NULL) 2629 bus_release_resource(dev, SYS_RES_IRQ, rid, que->res); 2630 } 2631 2632 2633 /* Clean the Legacy or Link interrupt last */ 2634 if (adapter->vector) /* we are doing MSIX */ 2635 rid = adapter->vector + 1; 2636 else 2637 (adapter->msix != 0) ? (rid = 1):(rid = 0); 2638 2639 if (adapter->tag != NULL) { 2640 bus_teardown_intr(dev, adapter->res, adapter->tag); 2641 adapter->tag = NULL; 2642 } 2643 if (adapter->res != NULL) 2644 bus_release_resource(dev, SYS_RES_IRQ, rid, adapter->res); 2645 2646 mem: 2647 if (adapter->msix) 2648 pci_release_msi(dev); 2649 2650 if (adapter->msix_mem != NULL) 2651 bus_release_resource(dev, SYS_RES_MEMORY, 2652 memrid, adapter->msix_mem); 2653 2654 if (adapter->pci_mem != NULL) 2655 bus_release_resource(dev, SYS_RES_MEMORY, 2656 PCIR_BAR(0), adapter->pci_mem); 2657 2658 return; 2659 } 2660 2661 /********************************************************************* 2662 * 2663 * Setup networking device structure and register an interface. 2664 * 2665 **********************************************************************/ 2666 static int 2667 ixgbe_setup_interface(device_t dev, struct adapter *adapter) 2668 { 2669 struct ifnet *ifp; 2670 2671 INIT_DEBUGOUT("ixgbe_setup_interface: begin"); 2672 2673 ifp = adapter->ifp = if_alloc(IFT_ETHER); 2674 if (ifp == NULL) { 2675 device_printf(dev, "can not allocate ifnet structure\n"); 2676 return (-1); 2677 } 2678 if_initname(ifp, device_get_name(dev), device_get_unit(dev)); 2679 ifp->if_baudrate = IF_Gbps(10); 2680 ifp->if_init = ixgbe_init; 2681 ifp->if_softc = adapter; 2682 ifp->if_flags = IFF_BROADCAST | IFF_SIMPLEX | IFF_MULTICAST; 2683 ifp->if_ioctl = ixgbe_ioctl; 2684 #if __FreeBSD_version >= 1100036 2685 if_setgetcounterfn(ifp, ixgbe_get_counter); 2686 #endif 2687 #if __FreeBSD_version >= 1100045 2688 /* TSO parameters */ 2689 ifp->if_hw_tsomax = 65518; 2690 ifp->if_hw_tsomaxsegcount = IXGBE_82599_SCATTER; 2691 ifp->if_hw_tsomaxsegsize = 2048; 2692 #endif 2693 #ifndef IXGBE_LEGACY_TX 2694 ifp->if_transmit = ixgbe_mq_start; 2695 ifp->if_qflush = ixgbe_qflush; 2696 #else 2697 ifp->if_start = ixgbe_start; 2698 IFQ_SET_MAXLEN(&ifp->if_snd, adapter->num_tx_desc - 2); 2699 ifp->if_snd.ifq_drv_maxlen = adapter->num_tx_desc - 2; 2700 IFQ_SET_READY(&ifp->if_snd); 2701 #endif 2702 2703 ether_ifattach(ifp, adapter->hw.mac.addr); 2704 2705 adapter->max_frame_size = 2706 ifp->if_mtu + ETHER_HDR_LEN + ETHER_CRC_LEN; 2707 2708 /* 2709 * Tell the upper layer(s) we support long frames. 2710 */ 2711 ifp->if_hdrlen = sizeof(struct ether_vlan_header); 2712 2713 ifp->if_capabilities |= IFCAP_HWCSUM | IFCAP_TSO | IFCAP_VLAN_HWCSUM; 2714 ifp->if_capabilities |= IFCAP_JUMBO_MTU; 2715 ifp->if_capabilities |= IFCAP_LRO; 2716 ifp->if_capabilities |= IFCAP_VLAN_HWTAGGING 2717 | IFCAP_VLAN_HWTSO 2718 | IFCAP_VLAN_MTU 2719 | IFCAP_HWSTATS; 2720 ifp->if_capenable = ifp->if_capabilities; 2721 2722 /* 2723 ** Don't turn this on by default, if vlans are 2724 ** created on another pseudo device (eg. lagg) 2725 ** then vlan events are not passed thru, breaking 2726 ** operation, but with HW FILTER off it works. If 2727 ** using vlans directly on the ixgbe driver you can 2728 ** enable this and get full hardware tag filtering. 2729 */ 2730 ifp->if_capabilities |= IFCAP_VLAN_HWFILTER; 2731 2732 /* 2733 * Specify the media types supported by this adapter and register 2734 * callbacks to update media and link information 2735 */ 2736 ifmedia_init(&adapter->media, IFM_IMASK, ixgbe_media_change, 2737 ixgbe_media_status); 2738 2739 ixgbe_add_media_types(adapter); 2740 2741 /* Autoselect media by default */ 2742 ifmedia_set(&adapter->media, IFM_ETHER | IFM_AUTO); 2743 2744 return (0); 2745 } 2746 2747 static void 2748 ixgbe_add_media_types(struct adapter *adapter) 2749 { 2750 struct ixgbe_hw *hw = &adapter->hw; 2751 device_t dev = adapter->dev; 2752 int layer; 2753 2754 layer = adapter->phy_layer = ixgbe_get_supported_physical_layer(hw); 2755 2756 /* Media types with matching FreeBSD media defines */ 2757 if (layer & IXGBE_PHYSICAL_LAYER_10GBASE_T) 2758 ifmedia_add(&adapter->media, IFM_ETHER | IFM_10G_T, 0, NULL); 2759 if (layer & IXGBE_PHYSICAL_LAYER_1000BASE_T) 2760 ifmedia_add(&adapter->media, IFM_ETHER | IFM_1000_T, 0, NULL); 2761 if (layer & IXGBE_PHYSICAL_LAYER_100BASE_TX) 2762 ifmedia_add(&adapter->media, IFM_ETHER | IFM_100_TX, 0, NULL); 2763 2764 if (layer & IXGBE_PHYSICAL_LAYER_SFP_PLUS_CU || 2765 layer & IXGBE_PHYSICAL_LAYER_SFP_ACTIVE_DA) 2766 ifmedia_add(&adapter->media, IFM_ETHER | IFM_10G_TWINAX, 0, NULL); 2767 2768 if (layer & IXGBE_PHYSICAL_LAYER_10GBASE_LR) 2769 ifmedia_add(&adapter->media, IFM_ETHER | IFM_10G_LR, 0, NULL); 2770 if (layer & IXGBE_PHYSICAL_LAYER_10GBASE_SR) 2771 ifmedia_add(&adapter->media, IFM_ETHER | IFM_10G_SR, 0, NULL); 2772 if (layer & IXGBE_PHYSICAL_LAYER_10GBASE_CX4) 2773 ifmedia_add(&adapter->media, IFM_ETHER | IFM_10G_CX4, 0, NULL); 2774 if (layer & IXGBE_PHYSICAL_LAYER_1000BASE_SX) 2775 ifmedia_add(&adapter->media, IFM_ETHER | IFM_1000_SX, 0, NULL); 2776 2777 /* 2778 ** Other (no matching FreeBSD media type): 2779 ** To workaround this, we'll assign these completely 2780 ** inappropriate media types. 2781 */ 2782 if (layer & IXGBE_PHYSICAL_LAYER_10GBASE_KR) { 2783 device_printf(dev, "Media supported: 10GbaseKR\n"); 2784 device_printf(dev, "10GbaseKR mapped to 10GbaseSR\n"); 2785 ifmedia_add(&adapter->media, IFM_ETHER | IFM_10G_SR, 0, NULL); 2786 } 2787 if (layer & IXGBE_PHYSICAL_LAYER_10GBASE_KX4) { 2788 device_printf(dev, "Media supported: 10GbaseKX4\n"); 2789 device_printf(dev, "10GbaseKX4 mapped to 10GbaseCX4\n"); 2790 ifmedia_add(&adapter->media, IFM_ETHER | IFM_10G_CX4, 0, NULL); 2791 } 2792 if (layer & IXGBE_PHYSICAL_LAYER_1000BASE_KX) { 2793 device_printf(dev, "Media supported: 1000baseKX\n"); 2794 device_printf(dev, "1000baseKX mapped to 1000baseCX\n"); 2795 ifmedia_add(&adapter->media, IFM_ETHER | IFM_1000_CX, 0, NULL); 2796 } 2797 if (layer & IXGBE_PHYSICAL_LAYER_1000BASE_BX) { 2798 /* Someday, someone will care about you... */ 2799 device_printf(dev, "Media supported: 1000baseBX\n"); 2800 } 2801 2802 if (hw->device_id == IXGBE_DEV_ID_82598AT) { 2803 ifmedia_add(&adapter->media, 2804 IFM_ETHER | IFM_1000_T | IFM_FDX, 0, NULL); 2805 ifmedia_add(&adapter->media, 2806 IFM_ETHER | IFM_1000_T, 0, NULL); 2807 } 2808 2809 ifmedia_add(&adapter->media, IFM_ETHER | IFM_AUTO, 0, NULL); 2810 } 2811 2812 static void 2813 ixgbe_config_link(struct adapter *adapter) 2814 { 2815 struct ixgbe_hw *hw = &adapter->hw; 2816 u32 autoneg, err = 0; 2817 bool sfp, negotiate; 2818 2819 sfp = ixgbe_is_sfp(hw); 2820 2821 if (sfp) { 2822 if (hw->phy.multispeed_fiber) { 2823 hw->mac.ops.setup_sfp(hw); 2824 ixgbe_enable_tx_laser(hw); 2825 taskqueue_enqueue(adapter->tq, &adapter->msf_task); 2826 } else 2827 taskqueue_enqueue(adapter->tq, &adapter->mod_task); 2828 } else { 2829 if (hw->mac.ops.check_link) 2830 err = ixgbe_check_link(hw, &adapter->link_speed, 2831 &adapter->link_up, FALSE); 2832 if (err) 2833 goto out; 2834 autoneg = hw->phy.autoneg_advertised; 2835 if ((!autoneg) && (hw->mac.ops.get_link_capabilities)) 2836 err = hw->mac.ops.get_link_capabilities(hw, 2837 &autoneg, &negotiate); 2838 if (err) 2839 goto out; 2840 if (hw->mac.ops.setup_link) 2841 err = hw->mac.ops.setup_link(hw, 2842 autoneg, adapter->link_up); 2843 } 2844 out: 2845 return; 2846 } 2847 2848 2849 /********************************************************************* 2850 * 2851 * Enable transmit units. 2852 * 2853 **********************************************************************/ 2854 static void 2855 ixgbe_initialize_transmit_units(struct adapter *adapter) 2856 { 2857 struct tx_ring *txr = adapter->tx_rings; 2858 struct ixgbe_hw *hw = &adapter->hw; 2859 2860 /* Setup the Base and Length of the Tx Descriptor Ring */ 2861 2862 for (int i = 0; i < adapter->num_queues; i++, txr++) { 2863 u64 tdba = txr->txdma.dma_paddr; 2864 u32 txctrl = 0; 2865 int j = txr->me; 2866 2867 IXGBE_WRITE_REG(hw, IXGBE_TDBAL(j), 2868 (tdba & 0x00000000ffffffffULL)); 2869 IXGBE_WRITE_REG(hw, IXGBE_TDBAH(j), (tdba >> 32)); 2870 IXGBE_WRITE_REG(hw, IXGBE_TDLEN(j), 2871 adapter->num_tx_desc * sizeof(union ixgbe_adv_tx_desc)); 2872 2873 /* Setup the HW Tx Head and Tail descriptor pointers */ 2874 IXGBE_WRITE_REG(hw, IXGBE_TDH(j), 0); 2875 IXGBE_WRITE_REG(hw, IXGBE_TDT(j), 0); 2876 2877 /* Cache the tail address */ 2878 txr->tail = IXGBE_TDT(j); 2879 2880 /* Set the processing limit */ 2881 txr->process_limit = ixgbe_tx_process_limit; 2882 2883 /* Disable Head Writeback */ 2884 switch (hw->mac.type) { 2885 case ixgbe_mac_82598EB: 2886 txctrl = IXGBE_READ_REG(hw, IXGBE_DCA_TXCTRL(j)); 2887 break; 2888 case ixgbe_mac_82599EB: 2889 case ixgbe_mac_X540: 2890 default: 2891 txctrl = IXGBE_READ_REG(hw, IXGBE_DCA_TXCTRL_82599(j)); 2892 break; 2893 } 2894 txctrl &= ~IXGBE_DCA_TXCTRL_DESC_WRO_EN; 2895 switch (hw->mac.type) { 2896 case ixgbe_mac_82598EB: 2897 IXGBE_WRITE_REG(hw, IXGBE_DCA_TXCTRL(j), txctrl); 2898 break; 2899 case ixgbe_mac_82599EB: 2900 case ixgbe_mac_X540: 2901 default: 2902 IXGBE_WRITE_REG(hw, IXGBE_DCA_TXCTRL_82599(j), txctrl); 2903 break; 2904 } 2905 2906 } 2907 2908 if (hw->mac.type != ixgbe_mac_82598EB) { 2909 u32 dmatxctl, rttdcs; 2910 #ifdef PCI_IOV 2911 enum ixgbe_iov_mode mode = ixgbe_get_iov_mode(adapter); 2912 #endif 2913 dmatxctl = IXGBE_READ_REG(hw, IXGBE_DMATXCTL); 2914 dmatxctl |= IXGBE_DMATXCTL_TE; 2915 IXGBE_WRITE_REG(hw, IXGBE_DMATXCTL, dmatxctl); 2916 /* Disable arbiter to set MTQC */ 2917 rttdcs = IXGBE_READ_REG(hw, IXGBE_RTTDCS); 2918 rttdcs |= IXGBE_RTTDCS_ARBDIS; 2919 IXGBE_WRITE_REG(hw, IXGBE_RTTDCS, rttdcs); 2920 #ifdef PCI_IOV 2921 IXGBE_WRITE_REG(hw, IXGBE_MTQC, ixgbe_get_mtqc(mode)); 2922 #else 2923 IXGBE_WRITE_REG(hw, IXGBE_MTQC, IXGBE_MTQC_64Q_1PB); 2924 #endif 2925 rttdcs &= ~IXGBE_RTTDCS_ARBDIS; 2926 IXGBE_WRITE_REG(hw, IXGBE_RTTDCS, rttdcs); 2927 } 2928 2929 return; 2930 } 2931 2932 static void 2933 ixgbe_initialise_rss_mapping(struct adapter *adapter) 2934 { 2935 struct ixgbe_hw *hw = &adapter->hw; 2936 u32 reta = 0, mrqc, rss_key[10]; 2937 int queue_id, table_size, index_mult; 2938 #ifdef RSS 2939 u32 rss_hash_config; 2940 #endif 2941 #ifdef PCI_IOV 2942 enum ixgbe_iov_mode mode; 2943 #endif 2944 2945 #ifdef RSS 2946 /* Fetch the configured RSS key */ 2947 rss_getkey((uint8_t *) &rss_key); 2948 #else 2949 /* set up random bits */ 2950 arc4rand(&rss_key, sizeof(rss_key), 0); 2951 #endif 2952 2953 /* Set multiplier for RETA setup and table size based on MAC */ 2954 index_mult = 0x1; 2955 table_size = 128; 2956 switch (adapter->hw.mac.type) { 2957 case ixgbe_mac_82598EB: 2958 index_mult = 0x11; 2959 break; 2960 case ixgbe_mac_X550: 2961 case ixgbe_mac_X550EM_x: 2962 table_size = 512; 2963 break; 2964 default: 2965 break; 2966 } 2967 2968 /* Set up the redirection table */ 2969 for (int i = 0, j = 0; i < table_size; i++, j++) { 2970 if (j == adapter->num_queues) j = 0; 2971 #ifdef RSS 2972 /* 2973 * Fetch the RSS bucket id for the given indirection entry. 2974 * Cap it at the number of configured buckets (which is 2975 * num_queues.) 2976 */ 2977 queue_id = rss_get_indirection_to_bucket(i); 2978 queue_id = queue_id % adapter->num_queues; 2979 #else 2980 queue_id = (j * index_mult); 2981 #endif 2982 /* 2983 * The low 8 bits are for hash value (n+0); 2984 * The next 8 bits are for hash value (n+1), etc. 2985 */ 2986 reta = reta >> 8; 2987 reta = reta | ( ((uint32_t) queue_id) << 24); 2988 if ((i & 3) == 3) { 2989 if (i < 128) 2990 IXGBE_WRITE_REG(hw, IXGBE_RETA(i >> 2), reta); 2991 else 2992 IXGBE_WRITE_REG(hw, IXGBE_ERETA((i >> 2) - 32), reta); 2993 reta = 0; 2994 } 2995 } 2996 2997 /* Now fill our hash function seeds */ 2998 for (int i = 0; i < 10; i++) 2999 IXGBE_WRITE_REG(hw, IXGBE_RSSRK(i), rss_key[i]); 3000 3001 /* Perform hash on these packet types */ 3002 #ifdef RSS 3003 mrqc = IXGBE_MRQC_RSSEN; 3004 rss_hash_config = rss_gethashconfig(); 3005 if (rss_hash_config & RSS_HASHTYPE_RSS_IPV4) 3006 mrqc |= IXGBE_MRQC_RSS_FIELD_IPV4; 3007 if (rss_hash_config & RSS_HASHTYPE_RSS_TCP_IPV4) 3008 mrqc |= IXGBE_MRQC_RSS_FIELD_IPV4_TCP; 3009 if (rss_hash_config & RSS_HASHTYPE_RSS_IPV6) 3010 mrqc |= IXGBE_MRQC_RSS_FIELD_IPV6; 3011 if (rss_hash_config & RSS_HASHTYPE_RSS_TCP_IPV6) 3012 mrqc |= IXGBE_MRQC_RSS_FIELD_IPV6_TCP; 3013 if (rss_hash_config & RSS_HASHTYPE_RSS_IPV6_EX) 3014 mrqc |= IXGBE_MRQC_RSS_FIELD_IPV6_EX; 3015 if (rss_hash_config & RSS_HASHTYPE_RSS_TCP_IPV6_EX) 3016 mrqc |= IXGBE_MRQC_RSS_FIELD_IPV6_EX_TCP; 3017 if (rss_hash_config & RSS_HASHTYPE_RSS_UDP_IPV4) 3018 mrqc |= IXGBE_MRQC_RSS_FIELD_IPV4_UDP; 3019 if (rss_hash_config & RSS_HASHTYPE_RSS_UDP_IPV4_EX) 3020 device_printf(adapter->dev, 3021 "%s: RSS_HASHTYPE_RSS_UDP_IPV4_EX defined, " 3022 "but not supported\n", __func__); 3023 if (rss_hash_config & RSS_HASHTYPE_RSS_UDP_IPV6) 3024 mrqc |= IXGBE_MRQC_RSS_FIELD_IPV6_UDP; 3025 if (rss_hash_config & RSS_HASHTYPE_RSS_UDP_IPV6_EX) 3026 mrqc |= IXGBE_MRQC_RSS_FIELD_IPV6_EX_UDP; 3027 #else 3028 /* 3029 * Disable UDP - IP fragments aren't currently being handled 3030 * and so we end up with a mix of 2-tuple and 4-tuple 3031 * traffic. 3032 */ 3033 mrqc = IXGBE_MRQC_RSSEN 3034 | IXGBE_MRQC_RSS_FIELD_IPV4 3035 | IXGBE_MRQC_RSS_FIELD_IPV4_TCP 3036 | IXGBE_MRQC_RSS_FIELD_IPV6_EX_TCP 3037 | IXGBE_MRQC_RSS_FIELD_IPV6_EX 3038 | IXGBE_MRQC_RSS_FIELD_IPV6 3039 | IXGBE_MRQC_RSS_FIELD_IPV6_TCP 3040 ; 3041 #endif /* RSS */ 3042 #ifdef PCI_IOV 3043 mode = ixgbe_get_iov_mode(adapter); 3044 mrqc |= ixgbe_get_mrqc(mode); 3045 #endif 3046 IXGBE_WRITE_REG(hw, IXGBE_MRQC, mrqc); 3047 } 3048 3049 3050 /********************************************************************* 3051 * 3052 * Setup receive registers and features. 3053 * 3054 **********************************************************************/ 3055 #define IXGBE_SRRCTL_BSIZEHDRSIZE_SHIFT 2 3056 3057 #define BSIZEPKT_ROUNDUP ((1<<IXGBE_SRRCTL_BSIZEPKT_SHIFT)-1) 3058 3059 static void 3060 ixgbe_initialize_receive_units(struct adapter *adapter) 3061 { 3062 struct rx_ring *rxr = adapter->rx_rings; 3063 struct ixgbe_hw *hw = &adapter->hw; 3064 struct ifnet *ifp = adapter->ifp; 3065 u32 bufsz, fctrl, srrctl, rxcsum; 3066 u32 hlreg; 3067 3068 3069 /* 3070 * Make sure receives are disabled while 3071 * setting up the descriptor ring 3072 */ 3073 ixgbe_disable_rx(hw); 3074 3075 /* Enable broadcasts */ 3076 fctrl = IXGBE_READ_REG(hw, IXGBE_FCTRL); 3077 fctrl |= IXGBE_FCTRL_BAM; 3078 if (adapter->hw.mac.type == ixgbe_mac_82598EB) { 3079 fctrl |= IXGBE_FCTRL_DPF; 3080 fctrl |= IXGBE_FCTRL_PMCF; 3081 } 3082 IXGBE_WRITE_REG(hw, IXGBE_FCTRL, fctrl); 3083 3084 /* Set for Jumbo Frames? */ 3085 hlreg = IXGBE_READ_REG(hw, IXGBE_HLREG0); 3086 if (ifp->if_mtu > ETHERMTU) 3087 hlreg |= IXGBE_HLREG0_JUMBOEN; 3088 else 3089 hlreg &= ~IXGBE_HLREG0_JUMBOEN; 3090 #ifdef DEV_NETMAP 3091 /* crcstrip is conditional in netmap (in RDRXCTL too ?) */ 3092 if (ifp->if_capenable & IFCAP_NETMAP && !ix_crcstrip) 3093 hlreg &= ~IXGBE_HLREG0_RXCRCSTRP; 3094 else 3095 hlreg |= IXGBE_HLREG0_RXCRCSTRP; 3096 #endif /* DEV_NETMAP */ 3097 IXGBE_WRITE_REG(hw, IXGBE_HLREG0, hlreg); 3098 3099 bufsz = (adapter->rx_mbuf_sz + 3100 BSIZEPKT_ROUNDUP) >> IXGBE_SRRCTL_BSIZEPKT_SHIFT; 3101 3102 for (int i = 0; i < adapter->num_queues; i++, rxr++) { 3103 u64 rdba = rxr->rxdma.dma_paddr; 3104 int j = rxr->me; 3105 3106 /* Setup the Base and Length of the Rx Descriptor Ring */ 3107 IXGBE_WRITE_REG(hw, IXGBE_RDBAL(j), 3108 (rdba & 0x00000000ffffffffULL)); 3109 IXGBE_WRITE_REG(hw, IXGBE_RDBAH(j), (rdba >> 32)); 3110 IXGBE_WRITE_REG(hw, IXGBE_RDLEN(j), 3111 adapter->num_rx_desc * sizeof(union ixgbe_adv_rx_desc)); 3112 3113 /* Set up the SRRCTL register */ 3114 srrctl = IXGBE_READ_REG(hw, IXGBE_SRRCTL(j)); 3115 srrctl &= ~IXGBE_SRRCTL_BSIZEHDR_MASK; 3116 srrctl &= ~IXGBE_SRRCTL_BSIZEPKT_MASK; 3117 srrctl |= bufsz; 3118 srrctl |= IXGBE_SRRCTL_DESCTYPE_ADV_ONEBUF; 3119 3120 /* 3121 * Set DROP_EN iff we have no flow control and >1 queue. 3122 * Note that srrctl was cleared shortly before during reset, 3123 * so we do not need to clear the bit, but do it just in case 3124 * this code is moved elsewhere. 3125 */ 3126 if (adapter->num_queues > 1 && 3127 adapter->hw.fc.requested_mode == ixgbe_fc_none) { 3128 srrctl |= IXGBE_SRRCTL_DROP_EN; 3129 } else { 3130 srrctl &= ~IXGBE_SRRCTL_DROP_EN; 3131 } 3132 3133 IXGBE_WRITE_REG(hw, IXGBE_SRRCTL(j), srrctl); 3134 3135 /* Setup the HW Rx Head and Tail Descriptor Pointers */ 3136 IXGBE_WRITE_REG(hw, IXGBE_RDH(j), 0); 3137 IXGBE_WRITE_REG(hw, IXGBE_RDT(j), 0); 3138 3139 /* Set the processing limit */ 3140 rxr->process_limit = ixgbe_rx_process_limit; 3141 3142 /* Set the driver rx tail address */ 3143 rxr->tail = IXGBE_RDT(rxr->me); 3144 } 3145 3146 if (adapter->hw.mac.type != ixgbe_mac_82598EB) { 3147 u32 psrtype = IXGBE_PSRTYPE_TCPHDR | 3148 IXGBE_PSRTYPE_UDPHDR | 3149 IXGBE_PSRTYPE_IPV4HDR | 3150 IXGBE_PSRTYPE_IPV6HDR; 3151 IXGBE_WRITE_REG(hw, IXGBE_PSRTYPE(0), psrtype); 3152 } 3153 3154 rxcsum = IXGBE_READ_REG(hw, IXGBE_RXCSUM); 3155 3156 ixgbe_initialise_rss_mapping(adapter); 3157 3158 if (adapter->num_queues > 1) { 3159 /* RSS and RX IPP Checksum are mutually exclusive */ 3160 rxcsum |= IXGBE_RXCSUM_PCSD; 3161 } 3162 3163 if (ifp->if_capenable & IFCAP_RXCSUM) 3164 rxcsum |= IXGBE_RXCSUM_PCSD; 3165 3166 if (!(rxcsum & IXGBE_RXCSUM_PCSD)) 3167 rxcsum |= IXGBE_RXCSUM_IPPCSE; 3168 3169 IXGBE_WRITE_REG(hw, IXGBE_RXCSUM, rxcsum); 3170 3171 return; 3172 } 3173 3174 3175 /* 3176 ** This routine is run via an vlan config EVENT, 3177 ** it enables us to use the HW Filter table since 3178 ** we can get the vlan id. This just creates the 3179 ** entry in the soft version of the VFTA, init will 3180 ** repopulate the real table. 3181 */ 3182 static void 3183 ixgbe_register_vlan(void *arg, struct ifnet *ifp, u16 vtag) 3184 { 3185 struct adapter *adapter = ifp->if_softc; 3186 u16 index, bit; 3187 3188 if (ifp->if_softc != arg) /* Not our event */ 3189 return; 3190 3191 if ((vtag == 0) || (vtag > 4095)) /* Invalid */ 3192 return; 3193 3194 IXGBE_CORE_LOCK(adapter); 3195 index = (vtag >> 5) & 0x7F; 3196 bit = vtag & 0x1F; 3197 adapter->shadow_vfta[index] |= (1 << bit); 3198 ++adapter->num_vlans; 3199 ixgbe_setup_vlan_hw_support(adapter); 3200 IXGBE_CORE_UNLOCK(adapter); 3201 } 3202 3203 /* 3204 ** This routine is run via an vlan 3205 ** unconfig EVENT, remove our entry 3206 ** in the soft vfta. 3207 */ 3208 static void 3209 ixgbe_unregister_vlan(void *arg, struct ifnet *ifp, u16 vtag) 3210 { 3211 struct adapter *adapter = ifp->if_softc; 3212 u16 index, bit; 3213 3214 if (ifp->if_softc != arg) 3215 return; 3216 3217 if ((vtag == 0) || (vtag > 4095)) /* Invalid */ 3218 return; 3219 3220 IXGBE_CORE_LOCK(adapter); 3221 index = (vtag >> 5) & 0x7F; 3222 bit = vtag & 0x1F; 3223 adapter->shadow_vfta[index] &= ~(1 << bit); 3224 --adapter->num_vlans; 3225 /* Re-init to load the changes */ 3226 ixgbe_setup_vlan_hw_support(adapter); 3227 IXGBE_CORE_UNLOCK(adapter); 3228 } 3229 3230 static void 3231 ixgbe_setup_vlan_hw_support(struct adapter *adapter) 3232 { 3233 struct ifnet *ifp = adapter->ifp; 3234 struct ixgbe_hw *hw = &adapter->hw; 3235 struct rx_ring *rxr; 3236 u32 ctrl; 3237 3238 3239 /* 3240 ** We get here thru init_locked, meaning 3241 ** a soft reset, this has already cleared 3242 ** the VFTA and other state, so if there 3243 ** have been no vlan's registered do nothing. 3244 */ 3245 if (adapter->num_vlans == 0) 3246 return; 3247 3248 /* Setup the queues for vlans */ 3249 for (int i = 0; i < adapter->num_queues; i++) { 3250 rxr = &adapter->rx_rings[i]; 3251 /* On 82599 the VLAN enable is per/queue in RXDCTL */ 3252 if (hw->mac.type != ixgbe_mac_82598EB) { 3253 ctrl = IXGBE_READ_REG(hw, IXGBE_RXDCTL(rxr->me)); 3254 ctrl |= IXGBE_RXDCTL_VME; 3255 IXGBE_WRITE_REG(hw, IXGBE_RXDCTL(rxr->me), ctrl); 3256 } 3257 rxr->vtag_strip = TRUE; 3258 } 3259 3260 if ((ifp->if_capenable & IFCAP_VLAN_HWFILTER) == 0) 3261 return; 3262 /* 3263 ** A soft reset zero's out the VFTA, so 3264 ** we need to repopulate it now. 3265 */ 3266 for (int i = 0; i < IXGBE_VFTA_SIZE; i++) 3267 if (adapter->shadow_vfta[i] != 0) 3268 IXGBE_WRITE_REG(hw, IXGBE_VFTA(i), 3269 adapter->shadow_vfta[i]); 3270 3271 ctrl = IXGBE_READ_REG(hw, IXGBE_VLNCTRL); 3272 /* Enable the Filter Table if enabled */ 3273 if (ifp->if_capenable & IFCAP_VLAN_HWFILTER) { 3274 ctrl &= ~IXGBE_VLNCTRL_CFIEN; 3275 ctrl |= IXGBE_VLNCTRL_VFE; 3276 } 3277 if (hw->mac.type == ixgbe_mac_82598EB) 3278 ctrl |= IXGBE_VLNCTRL_VME; 3279 IXGBE_WRITE_REG(hw, IXGBE_VLNCTRL, ctrl); 3280 } 3281 3282 static void 3283 ixgbe_enable_intr(struct adapter *adapter) 3284 { 3285 struct ixgbe_hw *hw = &adapter->hw; 3286 struct ix_queue *que = adapter->queues; 3287 u32 mask, fwsm; 3288 3289 mask = (IXGBE_EIMS_ENABLE_MASK & ~IXGBE_EIMS_RTX_QUEUE); 3290 /* Enable Fan Failure detection */ 3291 if (hw->device_id == IXGBE_DEV_ID_82598AT) 3292 mask |= IXGBE_EIMS_GPI_SDP1; 3293 3294 switch (adapter->hw.mac.type) { 3295 case ixgbe_mac_82599EB: 3296 mask |= IXGBE_EIMS_ECC; 3297 /* Temperature sensor on some adapters */ 3298 mask |= IXGBE_EIMS_GPI_SDP0; 3299 /* SFP+ (RX_LOS_N & MOD_ABS_N) */ 3300 mask |= IXGBE_EIMS_GPI_SDP1; 3301 mask |= IXGBE_EIMS_GPI_SDP2; 3302 #ifdef IXGBE_FDIR 3303 mask |= IXGBE_EIMS_FLOW_DIR; 3304 #endif 3305 #ifdef PCI_IOV 3306 mask |= IXGBE_EIMS_MAILBOX; 3307 #endif 3308 break; 3309 case ixgbe_mac_X540: 3310 /* Detect if Thermal Sensor is enabled */ 3311 fwsm = IXGBE_READ_REG(hw, IXGBE_FWSM); 3312 if (fwsm & IXGBE_FWSM_TS_ENABLED) 3313 mask |= IXGBE_EIMS_TS; 3314 mask |= IXGBE_EIMS_ECC; 3315 #ifdef IXGBE_FDIR 3316 mask |= IXGBE_EIMS_FLOW_DIR; 3317 #endif 3318 break; 3319 case ixgbe_mac_X550: 3320 case ixgbe_mac_X550EM_x: 3321 /* MAC thermal sensor is automatically enabled */ 3322 mask |= IXGBE_EIMS_TS; 3323 /* Some devices use SDP0 for important information */ 3324 if (hw->device_id == IXGBE_DEV_ID_X550EM_X_SFP || 3325 hw->device_id == IXGBE_DEV_ID_X550EM_X_10G_T) 3326 mask |= IXGBE_EIMS_GPI_SDP0_BY_MAC(hw); 3327 mask |= IXGBE_EIMS_ECC; 3328 #ifdef IXGBE_FDIR 3329 mask |= IXGBE_EIMS_FLOW_DIR; 3330 #endif 3331 #ifdef PCI_IOV 3332 mask |= IXGBE_EIMS_MAILBOX; 3333 #endif 3334 /* falls through */ 3335 default: 3336 break; 3337 } 3338 3339 IXGBE_WRITE_REG(hw, IXGBE_EIMS, mask); 3340 3341 /* With MSI-X we use auto clear */ 3342 if (adapter->msix_mem) { 3343 mask = IXGBE_EIMS_ENABLE_MASK; 3344 /* Don't autoclear Link */ 3345 mask &= ~IXGBE_EIMS_OTHER; 3346 mask &= ~IXGBE_EIMS_LSC; 3347 #ifdef PCI_IOV 3348 mask &= ~IXGBE_EIMS_MAILBOX; 3349 #endif 3350 IXGBE_WRITE_REG(hw, IXGBE_EIAC, mask); 3351 } 3352 3353 /* 3354 ** Now enable all queues, this is done separately to 3355 ** allow for handling the extended (beyond 32) MSIX 3356 ** vectors that can be used by 82599 3357 */ 3358 for (int i = 0; i < adapter->num_queues; i++, que++) 3359 ixgbe_enable_queue(adapter, que->msix); 3360 3361 IXGBE_WRITE_FLUSH(hw); 3362 3363 return; 3364 } 3365 3366 static void 3367 ixgbe_disable_intr(struct adapter *adapter) 3368 { 3369 if (adapter->msix_mem) 3370 IXGBE_WRITE_REG(&adapter->hw, IXGBE_EIAC, 0); 3371 if (adapter->hw.mac.type == ixgbe_mac_82598EB) { 3372 IXGBE_WRITE_REG(&adapter->hw, IXGBE_EIMC, ~0); 3373 } else { 3374 IXGBE_WRITE_REG(&adapter->hw, IXGBE_EIMC, 0xFFFF0000); 3375 IXGBE_WRITE_REG(&adapter->hw, IXGBE_EIMC_EX(0), ~0); 3376 IXGBE_WRITE_REG(&adapter->hw, IXGBE_EIMC_EX(1), ~0); 3377 } 3378 IXGBE_WRITE_FLUSH(&adapter->hw); 3379 return; 3380 } 3381 3382 /* 3383 ** Get the width and transaction speed of 3384 ** the slot this adapter is plugged into. 3385 */ 3386 static void 3387 ixgbe_get_slot_info(struct ixgbe_hw *hw) 3388 { 3389 device_t dev = ((struct ixgbe_osdep *)hw->back)->dev; 3390 struct ixgbe_mac_info *mac = &hw->mac; 3391 u16 link; 3392 u32 offset; 3393 3394 /* For most devices simply call the shared code routine */ 3395 if (hw->device_id != IXGBE_DEV_ID_82599_SFP_SF_QP) { 3396 ixgbe_get_bus_info(hw); 3397 /* These devices don't use PCI-E */ 3398 switch (hw->mac.type) { 3399 case ixgbe_mac_X550EM_x: 3400 return; 3401 default: 3402 goto display; 3403 } 3404 } 3405 3406 /* 3407 ** For the Quad port adapter we need to parse back 3408 ** up the PCI tree to find the speed of the expansion 3409 ** slot into which this adapter is plugged. A bit more work. 3410 */ 3411 dev = device_get_parent(device_get_parent(dev)); 3412 #ifdef IXGBE_DEBUG 3413 device_printf(dev, "parent pcib = %x,%x,%x\n", 3414 pci_get_bus(dev), pci_get_slot(dev), pci_get_function(dev)); 3415 #endif 3416 dev = device_get_parent(device_get_parent(dev)); 3417 #ifdef IXGBE_DEBUG 3418 device_printf(dev, "slot pcib = %x,%x,%x\n", 3419 pci_get_bus(dev), pci_get_slot(dev), pci_get_function(dev)); 3420 #endif 3421 /* Now get the PCI Express Capabilities offset */ 3422 pci_find_cap(dev, PCIY_EXPRESS, &offset); 3423 /* ...and read the Link Status Register */ 3424 link = pci_read_config(dev, offset + PCIER_LINK_STA, 2); 3425 switch (link & IXGBE_PCI_LINK_WIDTH) { 3426 case IXGBE_PCI_LINK_WIDTH_1: 3427 hw->bus.width = ixgbe_bus_width_pcie_x1; 3428 break; 3429 case IXGBE_PCI_LINK_WIDTH_2: 3430 hw->bus.width = ixgbe_bus_width_pcie_x2; 3431 break; 3432 case IXGBE_PCI_LINK_WIDTH_4: 3433 hw->bus.width = ixgbe_bus_width_pcie_x4; 3434 break; 3435 case IXGBE_PCI_LINK_WIDTH_8: 3436 hw->bus.width = ixgbe_bus_width_pcie_x8; 3437 break; 3438 default: 3439 hw->bus.width = ixgbe_bus_width_unknown; 3440 break; 3441 } 3442 3443 switch (link & IXGBE_PCI_LINK_SPEED) { 3444 case IXGBE_PCI_LINK_SPEED_2500: 3445 hw->bus.speed = ixgbe_bus_speed_2500; 3446 break; 3447 case IXGBE_PCI_LINK_SPEED_5000: 3448 hw->bus.speed = ixgbe_bus_speed_5000; 3449 break; 3450 case IXGBE_PCI_LINK_SPEED_8000: 3451 hw->bus.speed = ixgbe_bus_speed_8000; 3452 break; 3453 default: 3454 hw->bus.speed = ixgbe_bus_speed_unknown; 3455 break; 3456 } 3457 3458 mac->ops.set_lan_id(hw); 3459 3460 display: 3461 device_printf(dev,"PCI Express Bus: Speed %s %s\n", 3462 ((hw->bus.speed == ixgbe_bus_speed_8000) ? "8.0GT/s": 3463 (hw->bus.speed == ixgbe_bus_speed_5000) ? "5.0GT/s": 3464 (hw->bus.speed == ixgbe_bus_speed_2500) ? "2.5GT/s":"Unknown"), 3465 (hw->bus.width == ixgbe_bus_width_pcie_x8) ? "Width x8" : 3466 (hw->bus.width == ixgbe_bus_width_pcie_x4) ? "Width x4" : 3467 (hw->bus.width == ixgbe_bus_width_pcie_x1) ? "Width x1" : 3468 ("Unknown")); 3469 3470 if ((hw->device_id != IXGBE_DEV_ID_82599_SFP_SF_QP) && 3471 ((hw->bus.width <= ixgbe_bus_width_pcie_x4) && 3472 (hw->bus.speed == ixgbe_bus_speed_2500))) { 3473 device_printf(dev, "PCI-Express bandwidth available" 3474 " for this card\n is not sufficient for" 3475 " optimal performance.\n"); 3476 device_printf(dev, "For optimal performance a x8 " 3477 "PCIE, or x4 PCIE Gen2 slot is required.\n"); 3478 } 3479 if ((hw->device_id == IXGBE_DEV_ID_82599_SFP_SF_QP) && 3480 ((hw->bus.width <= ixgbe_bus_width_pcie_x8) && 3481 (hw->bus.speed < ixgbe_bus_speed_8000))) { 3482 device_printf(dev, "PCI-Express bandwidth available" 3483 " for this card\n is not sufficient for" 3484 " optimal performance.\n"); 3485 device_printf(dev, "For optimal performance a x8 " 3486 "PCIE Gen3 slot is required.\n"); 3487 } 3488 3489 return; 3490 } 3491 3492 3493 /* 3494 ** Setup the correct IVAR register for a particular MSIX interrupt 3495 ** (yes this is all very magic and confusing :) 3496 ** - entry is the register array entry 3497 ** - vector is the MSIX vector for this queue 3498 ** - type is RX/TX/MISC 3499 */ 3500 static void 3501 ixgbe_set_ivar(struct adapter *adapter, u8 entry, u8 vector, s8 type) 3502 { 3503 struct ixgbe_hw *hw = &adapter->hw; 3504 u32 ivar, index; 3505 3506 vector |= IXGBE_IVAR_ALLOC_VAL; 3507 3508 switch (hw->mac.type) { 3509 3510 case ixgbe_mac_82598EB: 3511 if (type == -1) 3512 entry = IXGBE_IVAR_OTHER_CAUSES_INDEX; 3513 else 3514 entry += (type * 64); 3515 index = (entry >> 2) & 0x1F; 3516 ivar = IXGBE_READ_REG(hw, IXGBE_IVAR(index)); 3517 ivar &= ~(0xFF << (8 * (entry & 0x3))); 3518 ivar |= (vector << (8 * (entry & 0x3))); 3519 IXGBE_WRITE_REG(&adapter->hw, IXGBE_IVAR(index), ivar); 3520 break; 3521 3522 case ixgbe_mac_82599EB: 3523 case ixgbe_mac_X540: 3524 case ixgbe_mac_X550: 3525 case ixgbe_mac_X550EM_x: 3526 if (type == -1) { /* MISC IVAR */ 3527 index = (entry & 1) * 8; 3528 ivar = IXGBE_READ_REG(hw, IXGBE_IVAR_MISC); 3529 ivar &= ~(0xFF << index); 3530 ivar |= (vector << index); 3531 IXGBE_WRITE_REG(hw, IXGBE_IVAR_MISC, ivar); 3532 } else { /* RX/TX IVARS */ 3533 index = (16 * (entry & 1)) + (8 * type); 3534 ivar = IXGBE_READ_REG(hw, IXGBE_IVAR(entry >> 1)); 3535 ivar &= ~(0xFF << index); 3536 ivar |= (vector << index); 3537 IXGBE_WRITE_REG(hw, IXGBE_IVAR(entry >> 1), ivar); 3538 } 3539 3540 default: 3541 break; 3542 } 3543 } 3544 3545 static void 3546 ixgbe_configure_ivars(struct adapter *adapter) 3547 { 3548 struct ix_queue *que = adapter->queues; 3549 u32 newitr; 3550 3551 if (ixgbe_max_interrupt_rate > 0) 3552 newitr = (4000000 / ixgbe_max_interrupt_rate) & 0x0FF8; 3553 else { 3554 /* 3555 ** Disable DMA coalescing if interrupt moderation is 3556 ** disabled. 3557 */ 3558 adapter->dmac = 0; 3559 newitr = 0; 3560 } 3561 3562 for (int i = 0; i < adapter->num_queues; i++, que++) { 3563 struct rx_ring *rxr = &adapter->rx_rings[i]; 3564 struct tx_ring *txr = &adapter->tx_rings[i]; 3565 /* First the RX queue entry */ 3566 ixgbe_set_ivar(adapter, rxr->me, que->msix, 0); 3567 /* ... and the TX */ 3568 ixgbe_set_ivar(adapter, txr->me, que->msix, 1); 3569 /* Set an Initial EITR value */ 3570 IXGBE_WRITE_REG(&adapter->hw, 3571 IXGBE_EITR(que->msix), newitr); 3572 } 3573 3574 /* For the Link interrupt */ 3575 ixgbe_set_ivar(adapter, 1, adapter->vector, -1); 3576 } 3577 3578 /* 3579 ** ixgbe_sfp_probe - called in the local timer to 3580 ** determine if a port had optics inserted. 3581 */ 3582 static bool 3583 ixgbe_sfp_probe(struct adapter *adapter) 3584 { 3585 struct ixgbe_hw *hw = &adapter->hw; 3586 device_t dev = adapter->dev; 3587 bool result = FALSE; 3588 3589 if ((hw->phy.type == ixgbe_phy_nl) && 3590 (hw->phy.sfp_type == ixgbe_sfp_type_not_present)) { 3591 s32 ret = hw->phy.ops.identify_sfp(hw); 3592 if (ret) 3593 goto out; 3594 ret = hw->phy.ops.reset(hw); 3595 if (ret == IXGBE_ERR_SFP_NOT_SUPPORTED) { 3596 device_printf(dev,"Unsupported SFP+ module detected!"); 3597 printf(" Reload driver with supported module.\n"); 3598 adapter->sfp_probe = FALSE; 3599 goto out; 3600 } else 3601 device_printf(dev,"SFP+ module detected!\n"); 3602 /* We now have supported optics */ 3603 adapter->sfp_probe = FALSE; 3604 /* Set the optics type so system reports correctly */ 3605 ixgbe_setup_optics(adapter); 3606 result = TRUE; 3607 } 3608 out: 3609 return (result); 3610 } 3611 3612 /* 3613 ** Tasklet handler for MSIX Link interrupts 3614 ** - do outside interrupt since it might sleep 3615 */ 3616 static void 3617 ixgbe_handle_link(void *context, int pending) 3618 { 3619 struct adapter *adapter = context; 3620 3621 ixgbe_check_link(&adapter->hw, 3622 &adapter->link_speed, &adapter->link_up, 0); 3623 ixgbe_update_link_status(adapter); 3624 } 3625 3626 /* 3627 ** Tasklet for handling SFP module interrupts 3628 */ 3629 static void 3630 ixgbe_handle_mod(void *context, int pending) 3631 { 3632 struct adapter *adapter = context; 3633 struct ixgbe_hw *hw = &adapter->hw; 3634 device_t dev = adapter->dev; 3635 u32 err; 3636 3637 err = hw->phy.ops.identify_sfp(hw); 3638 if (err == IXGBE_ERR_SFP_NOT_SUPPORTED) { 3639 device_printf(dev, 3640 "Unsupported SFP+ module type was detected.\n"); 3641 return; 3642 } 3643 3644 err = hw->mac.ops.setup_sfp(hw); 3645 if (err == IXGBE_ERR_SFP_NOT_SUPPORTED) { 3646 device_printf(dev, 3647 "Setup failure - unsupported SFP+ module type.\n"); 3648 return; 3649 } 3650 taskqueue_enqueue(adapter->tq, &adapter->msf_task); 3651 return; 3652 } 3653 3654 3655 /* 3656 ** Tasklet for handling MSF (multispeed fiber) interrupts 3657 */ 3658 static void 3659 ixgbe_handle_msf(void *context, int pending) 3660 { 3661 struct adapter *adapter = context; 3662 struct ixgbe_hw *hw = &adapter->hw; 3663 u32 autoneg; 3664 bool negotiate; 3665 int err; 3666 3667 err = hw->phy.ops.identify_sfp(hw); 3668 if (!err) { 3669 ixgbe_setup_optics(adapter); 3670 INIT_DEBUGOUT1("ixgbe_sfp_probe: flags: %X\n", adapter->optics); 3671 } 3672 3673 autoneg = hw->phy.autoneg_advertised; 3674 if ((!autoneg) && (hw->mac.ops.get_link_capabilities)) 3675 hw->mac.ops.get_link_capabilities(hw, &autoneg, &negotiate); 3676 if (hw->mac.ops.setup_link) 3677 hw->mac.ops.setup_link(hw, autoneg, TRUE); 3678 3679 ifmedia_removeall(&adapter->media); 3680 ixgbe_add_media_types(adapter); 3681 return; 3682 } 3683 3684 /* 3685 ** Tasklet for handling interrupts from an external PHY 3686 */ 3687 static void 3688 ixgbe_handle_phy(void *context, int pending) 3689 { 3690 struct adapter *adapter = context; 3691 struct ixgbe_hw *hw = &adapter->hw; 3692 int error; 3693 3694 error = hw->phy.ops.handle_lasi(hw); 3695 if (error == IXGBE_ERR_OVERTEMP) 3696 device_printf(adapter->dev, 3697 "CRITICAL: EXTERNAL PHY OVER TEMP!! " 3698 " PHY will downshift to lower power state!\n"); 3699 else if (error) 3700 device_printf(adapter->dev, 3701 "Error handling LASI interrupt: %d\n", 3702 error); 3703 return; 3704 } 3705 3706 #ifdef IXGBE_FDIR 3707 /* 3708 ** Tasklet for reinitializing the Flow Director filter table 3709 */ 3710 static void 3711 ixgbe_reinit_fdir(void *context, int pending) 3712 { 3713 struct adapter *adapter = context; 3714 struct ifnet *ifp = adapter->ifp; 3715 3716 if (adapter->fdir_reinit != 1) /* Shouldn't happen */ 3717 return; 3718 ixgbe_reinit_fdir_tables_82599(&adapter->hw); 3719 adapter->fdir_reinit = 0; 3720 /* re-enable flow director interrupts */ 3721 IXGBE_WRITE_REG(&adapter->hw, IXGBE_EIMS, IXGBE_EIMS_FLOW_DIR); 3722 /* Restart the interface */ 3723 ifp->if_drv_flags |= IFF_DRV_RUNNING; 3724 return; 3725 } 3726 #endif 3727 3728 /********************************************************************* 3729 * 3730 * Configure DMA Coalescing 3731 * 3732 **********************************************************************/ 3733 static void 3734 ixgbe_config_dmac(struct adapter *adapter) 3735 { 3736 struct ixgbe_hw *hw = &adapter->hw; 3737 struct ixgbe_dmac_config *dcfg = &hw->mac.dmac_config; 3738 3739 if (hw->mac.type < ixgbe_mac_X550 || 3740 !hw->mac.ops.dmac_config) 3741 return; 3742 3743 if (dcfg->watchdog_timer ^ adapter->dmac || 3744 dcfg->link_speed ^ adapter->link_speed) { 3745 dcfg->watchdog_timer = adapter->dmac; 3746 dcfg->fcoe_en = false; 3747 dcfg->link_speed = adapter->link_speed; 3748 dcfg->num_tcs = 1; 3749 3750 INIT_DEBUGOUT2("dmac settings: watchdog %d, link speed %d\n", 3751 dcfg->watchdog_timer, dcfg->link_speed); 3752 3753 hw->mac.ops.dmac_config(hw); 3754 } 3755 } 3756 3757 /* 3758 * Checks whether the adapter supports Energy Efficient Ethernet 3759 * or not, based on device ID. 3760 */ 3761 static void 3762 ixgbe_check_eee_support(struct adapter *adapter) 3763 { 3764 struct ixgbe_hw *hw = &adapter->hw; 3765 3766 adapter->eee_enabled = !!(hw->mac.ops.setup_eee); 3767 } 3768 3769 /* 3770 * Checks whether the adapter's ports are capable of 3771 * Wake On LAN by reading the adapter's NVM. 3772 * 3773 * Sets each port's hw->wol_enabled value depending 3774 * on the value read here. 3775 */ 3776 static void 3777 ixgbe_check_wol_support(struct adapter *adapter) 3778 { 3779 struct ixgbe_hw *hw = &adapter->hw; 3780 u16 dev_caps = 0; 3781 3782 /* Find out WoL support for port */ 3783 adapter->wol_support = hw->wol_enabled = 0; 3784 ixgbe_get_device_caps(hw, &dev_caps); 3785 if ((dev_caps & IXGBE_DEVICE_CAPS_WOL_PORT0_1) || 3786 ((dev_caps & IXGBE_DEVICE_CAPS_WOL_PORT0) && 3787 hw->bus.func == 0)) 3788 adapter->wol_support = hw->wol_enabled = 1; 3789 3790 /* Save initial wake up filter configuration */ 3791 adapter->wufc = IXGBE_READ_REG(hw, IXGBE_WUFC); 3792 3793 return; 3794 } 3795 3796 /* 3797 * Prepare the adapter/port for LPLU and/or WoL 3798 */ 3799 static int 3800 ixgbe_setup_low_power_mode(struct adapter *adapter) 3801 { 3802 struct ixgbe_hw *hw = &adapter->hw; 3803 device_t dev = adapter->dev; 3804 s32 error = 0; 3805 3806 mtx_assert(&adapter->core_mtx, MA_OWNED); 3807 3808 /* Limit power management flow to X550EM baseT */ 3809 if (hw->device_id == IXGBE_DEV_ID_X550EM_X_10G_T 3810 && hw->phy.ops.enter_lplu) { 3811 /* Turn off support for APM wakeup. (Using ACPI instead) */ 3812 IXGBE_WRITE_REG(hw, IXGBE_GRC, 3813 IXGBE_READ_REG(hw, IXGBE_GRC) & ~(u32)2); 3814 3815 /* 3816 * Clear Wake Up Status register to prevent any previous wakeup 3817 * events from waking us up immediately after we suspend. 3818 */ 3819 IXGBE_WRITE_REG(hw, IXGBE_WUS, 0xffffffff); 3820 3821 /* 3822 * Program the Wakeup Filter Control register with user filter 3823 * settings 3824 */ 3825 IXGBE_WRITE_REG(hw, IXGBE_WUFC, adapter->wufc); 3826 3827 /* Enable wakeups and power management in Wakeup Control */ 3828 IXGBE_WRITE_REG(hw, IXGBE_WUC, 3829 IXGBE_WUC_WKEN | IXGBE_WUC_PME_EN); 3830 3831 /* X550EM baseT adapters need a special LPLU flow */ 3832 hw->phy.reset_disable = true; 3833 ixgbe_stop(adapter); 3834 error = hw->phy.ops.enter_lplu(hw); 3835 if (error) 3836 device_printf(dev, 3837 "Error entering LPLU: %d\n", error); 3838 hw->phy.reset_disable = false; 3839 } else { 3840 /* Just stop for other adapters */ 3841 ixgbe_stop(adapter); 3842 } 3843 3844 return error; 3845 } 3846 3847 /********************************************************************** 3848 * 3849 * Update the board statistics counters. 3850 * 3851 **********************************************************************/ 3852 static void 3853 ixgbe_update_stats_counters(struct adapter *adapter) 3854 { 3855 struct ixgbe_hw *hw = &adapter->hw; 3856 u32 missed_rx = 0, bprc, lxon, lxoff, total; 3857 u64 total_missed_rx = 0; 3858 3859 adapter->stats.pf.crcerrs += IXGBE_READ_REG(hw, IXGBE_CRCERRS); 3860 adapter->stats.pf.illerrc += IXGBE_READ_REG(hw, IXGBE_ILLERRC); 3861 adapter->stats.pf.errbc += IXGBE_READ_REG(hw, IXGBE_ERRBC); 3862 adapter->stats.pf.mspdc += IXGBE_READ_REG(hw, IXGBE_MSPDC); 3863 3864 for (int i = 0; i < 16; i++) { 3865 adapter->stats.pf.qprc[i] += IXGBE_READ_REG(hw, IXGBE_QPRC(i)); 3866 adapter->stats.pf.qptc[i] += IXGBE_READ_REG(hw, IXGBE_QPTC(i)); 3867 adapter->stats.pf.qprdc[i] += IXGBE_READ_REG(hw, IXGBE_QPRDC(i)); 3868 } 3869 adapter->stats.pf.mlfc += IXGBE_READ_REG(hw, IXGBE_MLFC); 3870 adapter->stats.pf.mrfc += IXGBE_READ_REG(hw, IXGBE_MRFC); 3871 adapter->stats.pf.rlec += IXGBE_READ_REG(hw, IXGBE_RLEC); 3872 3873 /* Hardware workaround, gprc counts missed packets */ 3874 adapter->stats.pf.gprc += IXGBE_READ_REG(hw, IXGBE_GPRC); 3875 adapter->stats.pf.gprc -= missed_rx; 3876 3877 if (hw->mac.type != ixgbe_mac_82598EB) { 3878 adapter->stats.pf.gorc += IXGBE_READ_REG(hw, IXGBE_GORCL) + 3879 ((u64)IXGBE_READ_REG(hw, IXGBE_GORCH) << 32); 3880 adapter->stats.pf.gotc += IXGBE_READ_REG(hw, IXGBE_GOTCL) + 3881 ((u64)IXGBE_READ_REG(hw, IXGBE_GOTCH) << 32); 3882 adapter->stats.pf.tor += IXGBE_READ_REG(hw, IXGBE_TORL) + 3883 ((u64)IXGBE_READ_REG(hw, IXGBE_TORH) << 32); 3884 adapter->stats.pf.lxonrxc += IXGBE_READ_REG(hw, IXGBE_LXONRXCNT); 3885 adapter->stats.pf.lxoffrxc += IXGBE_READ_REG(hw, IXGBE_LXOFFRXCNT); 3886 } else { 3887 adapter->stats.pf.lxonrxc += IXGBE_READ_REG(hw, IXGBE_LXONRXC); 3888 adapter->stats.pf.lxoffrxc += IXGBE_READ_REG(hw, IXGBE_LXOFFRXC); 3889 /* 82598 only has a counter in the high register */ 3890 adapter->stats.pf.gorc += IXGBE_READ_REG(hw, IXGBE_GORCH); 3891 adapter->stats.pf.gotc += IXGBE_READ_REG(hw, IXGBE_GOTCH); 3892 adapter->stats.pf.tor += IXGBE_READ_REG(hw, IXGBE_TORH); 3893 } 3894 3895 /* 3896 * Workaround: mprc hardware is incorrectly counting 3897 * broadcasts, so for now we subtract those. 3898 */ 3899 bprc = IXGBE_READ_REG(hw, IXGBE_BPRC); 3900 adapter->stats.pf.bprc += bprc; 3901 adapter->stats.pf.mprc += IXGBE_READ_REG(hw, IXGBE_MPRC); 3902 if (hw->mac.type == ixgbe_mac_82598EB) 3903 adapter->stats.pf.mprc -= bprc; 3904 3905 adapter->stats.pf.prc64 += IXGBE_READ_REG(hw, IXGBE_PRC64); 3906 adapter->stats.pf.prc127 += IXGBE_READ_REG(hw, IXGBE_PRC127); 3907 adapter->stats.pf.prc255 += IXGBE_READ_REG(hw, IXGBE_PRC255); 3908 adapter->stats.pf.prc511 += IXGBE_READ_REG(hw, IXGBE_PRC511); 3909 adapter->stats.pf.prc1023 += IXGBE_READ_REG(hw, IXGBE_PRC1023); 3910 adapter->stats.pf.prc1522 += IXGBE_READ_REG(hw, IXGBE_PRC1522); 3911 3912 lxon = IXGBE_READ_REG(hw, IXGBE_LXONTXC); 3913 adapter->stats.pf.lxontxc += lxon; 3914 lxoff = IXGBE_READ_REG(hw, IXGBE_LXOFFTXC); 3915 adapter->stats.pf.lxofftxc += lxoff; 3916 total = lxon + lxoff; 3917 3918 adapter->stats.pf.gptc += IXGBE_READ_REG(hw, IXGBE_GPTC); 3919 adapter->stats.pf.mptc += IXGBE_READ_REG(hw, IXGBE_MPTC); 3920 adapter->stats.pf.ptc64 += IXGBE_READ_REG(hw, IXGBE_PTC64); 3921 adapter->stats.pf.gptc -= total; 3922 adapter->stats.pf.mptc -= total; 3923 adapter->stats.pf.ptc64 -= total; 3924 adapter->stats.pf.gotc -= total * ETHER_MIN_LEN; 3925 3926 adapter->stats.pf.ruc += IXGBE_READ_REG(hw, IXGBE_RUC); 3927 adapter->stats.pf.rfc += IXGBE_READ_REG(hw, IXGBE_RFC); 3928 adapter->stats.pf.roc += IXGBE_READ_REG(hw, IXGBE_ROC); 3929 adapter->stats.pf.rjc += IXGBE_READ_REG(hw, IXGBE_RJC); 3930 adapter->stats.pf.mngprc += IXGBE_READ_REG(hw, IXGBE_MNGPRC); 3931 adapter->stats.pf.mngpdc += IXGBE_READ_REG(hw, IXGBE_MNGPDC); 3932 adapter->stats.pf.mngptc += IXGBE_READ_REG(hw, IXGBE_MNGPTC); 3933 adapter->stats.pf.tpr += IXGBE_READ_REG(hw, IXGBE_TPR); 3934 adapter->stats.pf.tpt += IXGBE_READ_REG(hw, IXGBE_TPT); 3935 adapter->stats.pf.ptc127 += IXGBE_READ_REG(hw, IXGBE_PTC127); 3936 adapter->stats.pf.ptc255 += IXGBE_READ_REG(hw, IXGBE_PTC255); 3937 adapter->stats.pf.ptc511 += IXGBE_READ_REG(hw, IXGBE_PTC511); 3938 adapter->stats.pf.ptc1023 += IXGBE_READ_REG(hw, IXGBE_PTC1023); 3939 adapter->stats.pf.ptc1522 += IXGBE_READ_REG(hw, IXGBE_PTC1522); 3940 adapter->stats.pf.bptc += IXGBE_READ_REG(hw, IXGBE_BPTC); 3941 adapter->stats.pf.xec += IXGBE_READ_REG(hw, IXGBE_XEC); 3942 adapter->stats.pf.fccrc += IXGBE_READ_REG(hw, IXGBE_FCCRC); 3943 adapter->stats.pf.fclast += IXGBE_READ_REG(hw, IXGBE_FCLAST); 3944 /* Only read FCOE on 82599 */ 3945 if (hw->mac.type != ixgbe_mac_82598EB) { 3946 adapter->stats.pf.fcoerpdc += IXGBE_READ_REG(hw, IXGBE_FCOERPDC); 3947 adapter->stats.pf.fcoeprc += IXGBE_READ_REG(hw, IXGBE_FCOEPRC); 3948 adapter->stats.pf.fcoeptc += IXGBE_READ_REG(hw, IXGBE_FCOEPTC); 3949 adapter->stats.pf.fcoedwrc += IXGBE_READ_REG(hw, IXGBE_FCOEDWRC); 3950 adapter->stats.pf.fcoedwtc += IXGBE_READ_REG(hw, IXGBE_FCOEDWTC); 3951 } 3952 3953 /* Fill out the OS statistics structure */ 3954 IXGBE_SET_IPACKETS(adapter, adapter->stats.pf.gprc); 3955 IXGBE_SET_OPACKETS(adapter, adapter->stats.pf.gptc); 3956 IXGBE_SET_IBYTES(adapter, adapter->stats.pf.gorc); 3957 IXGBE_SET_OBYTES(adapter, adapter->stats.pf.gotc); 3958 IXGBE_SET_IMCASTS(adapter, adapter->stats.pf.mprc); 3959 IXGBE_SET_OMCASTS(adapter, adapter->stats.pf.mptc); 3960 IXGBE_SET_COLLISIONS(adapter, 0); 3961 IXGBE_SET_IQDROPS(adapter, total_missed_rx); 3962 IXGBE_SET_IERRORS(adapter, adapter->stats.pf.crcerrs 3963 + adapter->stats.pf.rlec); 3964 } 3965 3966 #if __FreeBSD_version >= 1100036 3967 static uint64_t 3968 ixgbe_get_counter(struct ifnet *ifp, ift_counter cnt) 3969 { 3970 struct adapter *adapter; 3971 struct tx_ring *txr; 3972 uint64_t rv; 3973 3974 adapter = if_getsoftc(ifp); 3975 3976 switch (cnt) { 3977 case IFCOUNTER_IPACKETS: 3978 return (adapter->ipackets); 3979 case IFCOUNTER_OPACKETS: 3980 return (adapter->opackets); 3981 case IFCOUNTER_IBYTES: 3982 return (adapter->ibytes); 3983 case IFCOUNTER_OBYTES: 3984 return (adapter->obytes); 3985 case IFCOUNTER_IMCASTS: 3986 return (adapter->imcasts); 3987 case IFCOUNTER_OMCASTS: 3988 return (adapter->omcasts); 3989 case IFCOUNTER_COLLISIONS: 3990 return (0); 3991 case IFCOUNTER_IQDROPS: 3992 return (adapter->iqdrops); 3993 case IFCOUNTER_OQDROPS: 3994 rv = 0; 3995 txr = adapter->tx_rings; 3996 for (int i = 0; i < adapter->num_queues; i++, txr++) 3997 rv += txr->br->br_drops; 3998 return (rv); 3999 case IFCOUNTER_IERRORS: 4000 return (adapter->ierrors); 4001 default: 4002 return (if_get_counter_default(ifp, cnt)); 4003 } 4004 } 4005 #endif 4006 4007 /** ixgbe_sysctl_tdh_handler - Handler function 4008 * Retrieves the TDH value from the hardware 4009 */ 4010 static int 4011 ixgbe_sysctl_tdh_handler(SYSCTL_HANDLER_ARGS) 4012 { 4013 int error; 4014 4015 struct tx_ring *txr = ((struct tx_ring *)oidp->oid_arg1); 4016 if (!txr) return 0; 4017 4018 unsigned val = IXGBE_READ_REG(&txr->adapter->hw, IXGBE_TDH(txr->me)); 4019 error = sysctl_handle_int(oidp, &val, 0, req); 4020 if (error || !req->newptr) 4021 return error; 4022 return 0; 4023 } 4024 4025 /** ixgbe_sysctl_tdt_handler - Handler function 4026 * Retrieves the TDT value from the hardware 4027 */ 4028 static int 4029 ixgbe_sysctl_tdt_handler(SYSCTL_HANDLER_ARGS) 4030 { 4031 int error; 4032 4033 struct tx_ring *txr = ((struct tx_ring *)oidp->oid_arg1); 4034 if (!txr) return 0; 4035 4036 unsigned val = IXGBE_READ_REG(&txr->adapter->hw, IXGBE_TDT(txr->me)); 4037 error = sysctl_handle_int(oidp, &val, 0, req); 4038 if (error || !req->newptr) 4039 return error; 4040 return 0; 4041 } 4042 4043 /** ixgbe_sysctl_rdh_handler - Handler function 4044 * Retrieves the RDH value from the hardware 4045 */ 4046 static int 4047 ixgbe_sysctl_rdh_handler(SYSCTL_HANDLER_ARGS) 4048 { 4049 int error; 4050 4051 struct rx_ring *rxr = ((struct rx_ring *)oidp->oid_arg1); 4052 if (!rxr) return 0; 4053 4054 unsigned val = IXGBE_READ_REG(&rxr->adapter->hw, IXGBE_RDH(rxr->me)); 4055 error = sysctl_handle_int(oidp, &val, 0, req); 4056 if (error || !req->newptr) 4057 return error; 4058 return 0; 4059 } 4060 4061 /** ixgbe_sysctl_rdt_handler - Handler function 4062 * Retrieves the RDT value from the hardware 4063 */ 4064 static int 4065 ixgbe_sysctl_rdt_handler(SYSCTL_HANDLER_ARGS) 4066 { 4067 int error; 4068 4069 struct rx_ring *rxr = ((struct rx_ring *)oidp->oid_arg1); 4070 if (!rxr) return 0; 4071 4072 unsigned val = IXGBE_READ_REG(&rxr->adapter->hw, IXGBE_RDT(rxr->me)); 4073 error = sysctl_handle_int(oidp, &val, 0, req); 4074 if (error || !req->newptr) 4075 return error; 4076 return 0; 4077 } 4078 4079 static int 4080 ixgbe_sysctl_interrupt_rate_handler(SYSCTL_HANDLER_ARGS) 4081 { 4082 int error; 4083 struct ix_queue *que = ((struct ix_queue *)oidp->oid_arg1); 4084 unsigned int reg, usec, rate; 4085 4086 reg = IXGBE_READ_REG(&que->adapter->hw, IXGBE_EITR(que->msix)); 4087 usec = ((reg & 0x0FF8) >> 3); 4088 if (usec > 0) 4089 rate = 500000 / usec; 4090 else 4091 rate = 0; 4092 error = sysctl_handle_int(oidp, &rate, 0, req); 4093 if (error || !req->newptr) 4094 return error; 4095 reg &= ~0xfff; /* default, no limitation */ 4096 ixgbe_max_interrupt_rate = 0; 4097 if (rate > 0 && rate < 500000) { 4098 if (rate < 1000) 4099 rate = 1000; 4100 ixgbe_max_interrupt_rate = rate; 4101 reg |= ((4000000/rate) & 0xff8 ); 4102 } 4103 IXGBE_WRITE_REG(&que->adapter->hw, IXGBE_EITR(que->msix), reg); 4104 return 0; 4105 } 4106 4107 static void 4108 ixgbe_add_device_sysctls(struct adapter *adapter) 4109 { 4110 device_t dev = adapter->dev; 4111 struct ixgbe_hw *hw = &adapter->hw; 4112 struct sysctl_oid_list *child; 4113 struct sysctl_ctx_list *ctx; 4114 4115 ctx = device_get_sysctl_ctx(dev); 4116 child = SYSCTL_CHILDREN(device_get_sysctl_tree(dev)); 4117 4118 /* Sysctls for all devices */ 4119 SYSCTL_ADD_PROC(ctx, child, OID_AUTO, "fc", 4120 CTLTYPE_INT | CTLFLAG_RW, adapter, 0, 4121 ixgbe_set_flowcntl, "I", IXGBE_SYSCTL_DESC_SET_FC); 4122 4123 SYSCTL_ADD_INT(ctx, child, OID_AUTO, "enable_aim", 4124 CTLFLAG_RW, 4125 &ixgbe_enable_aim, 1, "Interrupt Moderation"); 4126 4127 SYSCTL_ADD_PROC(ctx, child, OID_AUTO, "advertise_speed", 4128 CTLTYPE_INT | CTLFLAG_RW, adapter, 0, 4129 ixgbe_set_advertise, "I", IXGBE_SYSCTL_DESC_ADV_SPEED); 4130 4131 SYSCTL_ADD_PROC(ctx, child, OID_AUTO, "thermal_test", 4132 CTLTYPE_INT | CTLFLAG_RW, adapter, 0, 4133 ixgbe_sysctl_thermal_test, "I", "Thermal Test"); 4134 4135 /* for X550 devices */ 4136 if (hw->mac.type >= ixgbe_mac_X550) 4137 SYSCTL_ADD_PROC(ctx, child, OID_AUTO, "dmac", 4138 CTLTYPE_INT | CTLFLAG_RW, adapter, 0, 4139 ixgbe_sysctl_dmac, "I", "DMA Coalesce"); 4140 4141 /* for X550T and X550EM backplane devices */ 4142 if (hw->mac.ops.setup_eee) { 4143 struct sysctl_oid *eee_node; 4144 struct sysctl_oid_list *eee_list; 4145 4146 eee_node = SYSCTL_ADD_NODE(ctx, child, OID_AUTO, "eee", 4147 CTLFLAG_RD, NULL, 4148 "Energy Efficient Ethernet sysctls"); 4149 eee_list = SYSCTL_CHILDREN(eee_node); 4150 4151 SYSCTL_ADD_PROC(ctx, eee_list, OID_AUTO, "enable", 4152 CTLTYPE_INT | CTLFLAG_RW, adapter, 0, 4153 ixgbe_sysctl_eee_enable, "I", 4154 "Enable or Disable EEE"); 4155 4156 SYSCTL_ADD_PROC(ctx, eee_list, OID_AUTO, "negotiated", 4157 CTLTYPE_INT | CTLFLAG_RD, adapter, 0, 4158 ixgbe_sysctl_eee_negotiated, "I", 4159 "EEE negotiated on link"); 4160 4161 SYSCTL_ADD_PROC(ctx, eee_list, OID_AUTO, "tx_lpi_status", 4162 CTLTYPE_INT | CTLFLAG_RD, adapter, 0, 4163 ixgbe_sysctl_eee_tx_lpi_status, "I", 4164 "Whether or not TX link is in LPI state"); 4165 4166 SYSCTL_ADD_PROC(ctx, eee_list, OID_AUTO, "rx_lpi_status", 4167 CTLTYPE_INT | CTLFLAG_RD, adapter, 0, 4168 ixgbe_sysctl_eee_rx_lpi_status, "I", 4169 "Whether or not RX link is in LPI state"); 4170 } 4171 4172 /* for certain 10GBaseT devices */ 4173 if (hw->device_id == IXGBE_DEV_ID_X550T || 4174 hw->device_id == IXGBE_DEV_ID_X550EM_X_10G_T) { 4175 SYSCTL_ADD_PROC(ctx, child, OID_AUTO, "wol_enable", 4176 CTLTYPE_INT | CTLFLAG_RW, adapter, 0, 4177 ixgbe_sysctl_wol_enable, "I", 4178 "Enable/Disable Wake on LAN"); 4179 4180 SYSCTL_ADD_PROC(ctx, child, OID_AUTO, "wufc", 4181 CTLTYPE_INT | CTLFLAG_RW, adapter, 0, 4182 ixgbe_sysctl_wufc, "I", 4183 "Enable/Disable Wake Up Filters"); 4184 } 4185 4186 /* for X550EM 10GBaseT devices */ 4187 if (hw->device_id == IXGBE_DEV_ID_X550EM_X_10G_T) { 4188 struct sysctl_oid *phy_node; 4189 struct sysctl_oid_list *phy_list; 4190 4191 phy_node = SYSCTL_ADD_NODE(ctx, child, OID_AUTO, "phy", 4192 CTLFLAG_RD, NULL, 4193 "External PHY sysctls"); 4194 phy_list = SYSCTL_CHILDREN(phy_node); 4195 4196 SYSCTL_ADD_PROC(ctx, phy_list, OID_AUTO, "temp", 4197 CTLTYPE_INT | CTLFLAG_RD, adapter, 0, 4198 ixgbe_sysctl_phy_temp, "I", 4199 "Current External PHY Temperature (Celsius)"); 4200 4201 SYSCTL_ADD_PROC(ctx, phy_list, OID_AUTO, "overtemp_occurred", 4202 CTLTYPE_INT | CTLFLAG_RD, adapter, 0, 4203 ixgbe_sysctl_phy_overtemp_occurred, "I", 4204 "External PHY High Temperature Event Occurred"); 4205 } 4206 } 4207 4208 /* 4209 * Add sysctl variables, one per statistic, to the system. 4210 */ 4211 static void 4212 ixgbe_add_hw_stats(struct adapter *adapter) 4213 { 4214 device_t dev = adapter->dev; 4215 4216 struct tx_ring *txr = adapter->tx_rings; 4217 struct rx_ring *rxr = adapter->rx_rings; 4218 4219 struct sysctl_ctx_list *ctx = device_get_sysctl_ctx(dev); 4220 struct sysctl_oid *tree = device_get_sysctl_tree(dev); 4221 struct sysctl_oid_list *child = SYSCTL_CHILDREN(tree); 4222 struct ixgbe_hw_stats *stats = &adapter->stats.pf; 4223 4224 struct sysctl_oid *stat_node, *queue_node; 4225 struct sysctl_oid_list *stat_list, *queue_list; 4226 4227 #define QUEUE_NAME_LEN 32 4228 char namebuf[QUEUE_NAME_LEN]; 4229 4230 /* Driver Statistics */ 4231 SYSCTL_ADD_ULONG(ctx, child, OID_AUTO, "dropped", 4232 CTLFLAG_RD, &adapter->dropped_pkts, 4233 "Driver dropped packets"); 4234 SYSCTL_ADD_ULONG(ctx, child, OID_AUTO, "mbuf_defrag_failed", 4235 CTLFLAG_RD, &adapter->mbuf_defrag_failed, 4236 "m_defrag() failed"); 4237 SYSCTL_ADD_ULONG(ctx, child, OID_AUTO, "watchdog_events", 4238 CTLFLAG_RD, &adapter->watchdog_events, 4239 "Watchdog timeouts"); 4240 SYSCTL_ADD_ULONG(ctx, child, OID_AUTO, "link_irq", 4241 CTLFLAG_RD, &adapter->link_irq, 4242 "Link MSIX IRQ Handled"); 4243 4244 for (int i = 0; i < adapter->num_queues; i++, txr++) { 4245 snprintf(namebuf, QUEUE_NAME_LEN, "queue%d", i); 4246 queue_node = SYSCTL_ADD_NODE(ctx, child, OID_AUTO, namebuf, 4247 CTLFLAG_RD, NULL, "Queue Name"); 4248 queue_list = SYSCTL_CHILDREN(queue_node); 4249 4250 SYSCTL_ADD_PROC(ctx, queue_list, OID_AUTO, "interrupt_rate", 4251 CTLTYPE_UINT | CTLFLAG_RW, &adapter->queues[i], 4252 sizeof(&adapter->queues[i]), 4253 ixgbe_sysctl_interrupt_rate_handler, "IU", 4254 "Interrupt Rate"); 4255 SYSCTL_ADD_UQUAD(ctx, queue_list, OID_AUTO, "irqs", 4256 CTLFLAG_RD, &(adapter->queues[i].irqs), 4257 "irqs on this queue"); 4258 SYSCTL_ADD_PROC(ctx, queue_list, OID_AUTO, "txd_head", 4259 CTLTYPE_UINT | CTLFLAG_RD, txr, sizeof(txr), 4260 ixgbe_sysctl_tdh_handler, "IU", 4261 "Transmit Descriptor Head"); 4262 SYSCTL_ADD_PROC(ctx, queue_list, OID_AUTO, "txd_tail", 4263 CTLTYPE_UINT | CTLFLAG_RD, txr, sizeof(txr), 4264 ixgbe_sysctl_tdt_handler, "IU", 4265 "Transmit Descriptor Tail"); 4266 SYSCTL_ADD_ULONG(ctx, queue_list, OID_AUTO, "tso_tx", 4267 CTLFLAG_RD, &txr->tso_tx, 4268 "TSO"); 4269 SYSCTL_ADD_ULONG(ctx, queue_list, OID_AUTO, "no_tx_dma_setup", 4270 CTLFLAG_RD, &txr->no_tx_dma_setup, 4271 "Driver tx dma failure in xmit"); 4272 SYSCTL_ADD_UQUAD(ctx, queue_list, OID_AUTO, "no_desc_avail", 4273 CTLFLAG_RD, &txr->no_desc_avail, 4274 "Queue No Descriptor Available"); 4275 SYSCTL_ADD_UQUAD(ctx, queue_list, OID_AUTO, "tx_packets", 4276 CTLFLAG_RD, &txr->total_packets, 4277 "Queue Packets Transmitted"); 4278 SYSCTL_ADD_UQUAD(ctx, queue_list, OID_AUTO, "br_drops", 4279 CTLFLAG_RD, &txr->br->br_drops, 4280 "Packets dropped in buf_ring"); 4281 } 4282 4283 for (int i = 0; i < adapter->num_queues; i++, rxr++) { 4284 snprintf(namebuf, QUEUE_NAME_LEN, "queue%d", i); 4285 queue_node = SYSCTL_ADD_NODE(ctx, child, OID_AUTO, namebuf, 4286 CTLFLAG_RD, NULL, "Queue Name"); 4287 queue_list = SYSCTL_CHILDREN(queue_node); 4288 4289 struct lro_ctrl *lro = &rxr->lro; 4290 4291 snprintf(namebuf, QUEUE_NAME_LEN, "queue%d", i); 4292 queue_node = SYSCTL_ADD_NODE(ctx, child, OID_AUTO, namebuf, 4293 CTLFLAG_RD, NULL, "Queue Name"); 4294 queue_list = SYSCTL_CHILDREN(queue_node); 4295 4296 SYSCTL_ADD_PROC(ctx, queue_list, OID_AUTO, "rxd_head", 4297 CTLTYPE_UINT | CTLFLAG_RD, rxr, sizeof(rxr), 4298 ixgbe_sysctl_rdh_handler, "IU", 4299 "Receive Descriptor Head"); 4300 SYSCTL_ADD_PROC(ctx, queue_list, OID_AUTO, "rxd_tail", 4301 CTLTYPE_UINT | CTLFLAG_RD, rxr, sizeof(rxr), 4302 ixgbe_sysctl_rdt_handler, "IU", 4303 "Receive Descriptor Tail"); 4304 SYSCTL_ADD_UQUAD(ctx, queue_list, OID_AUTO, "rx_packets", 4305 CTLFLAG_RD, &rxr->rx_packets, 4306 "Queue Packets Received"); 4307 SYSCTL_ADD_UQUAD(ctx, queue_list, OID_AUTO, "rx_bytes", 4308 CTLFLAG_RD, &rxr->rx_bytes, 4309 "Queue Bytes Received"); 4310 SYSCTL_ADD_UQUAD(ctx, queue_list, OID_AUTO, "rx_copies", 4311 CTLFLAG_RD, &rxr->rx_copies, 4312 "Copied RX Frames"); 4313 SYSCTL_ADD_INT(ctx, queue_list, OID_AUTO, "lro_queued", 4314 CTLFLAG_RD, &lro->lro_queued, 0, 4315 "LRO Queued"); 4316 SYSCTL_ADD_INT(ctx, queue_list, OID_AUTO, "lro_flushed", 4317 CTLFLAG_RD, &lro->lro_flushed, 0, 4318 "LRO Flushed"); 4319 } 4320 4321 /* MAC stats get the own sub node */ 4322 4323 stat_node = SYSCTL_ADD_NODE(ctx, child, OID_AUTO, "mac_stats", 4324 CTLFLAG_RD, NULL, "MAC Statistics"); 4325 stat_list = SYSCTL_CHILDREN(stat_node); 4326 4327 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "crc_errs", 4328 CTLFLAG_RD, &stats->crcerrs, 4329 "CRC Errors"); 4330 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "ill_errs", 4331 CTLFLAG_RD, &stats->illerrc, 4332 "Illegal Byte Errors"); 4333 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "byte_errs", 4334 CTLFLAG_RD, &stats->errbc, 4335 "Byte Errors"); 4336 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "short_discards", 4337 CTLFLAG_RD, &stats->mspdc, 4338 "MAC Short Packets Discarded"); 4339 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "local_faults", 4340 CTLFLAG_RD, &stats->mlfc, 4341 "MAC Local Faults"); 4342 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "remote_faults", 4343 CTLFLAG_RD, &stats->mrfc, 4344 "MAC Remote Faults"); 4345 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "rec_len_errs", 4346 CTLFLAG_RD, &stats->rlec, 4347 "Receive Length Errors"); 4348 4349 /* Flow Control stats */ 4350 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "xon_txd", 4351 CTLFLAG_RD, &stats->lxontxc, 4352 "Link XON Transmitted"); 4353 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "xon_recvd", 4354 CTLFLAG_RD, &stats->lxonrxc, 4355 "Link XON Received"); 4356 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "xoff_txd", 4357 CTLFLAG_RD, &stats->lxofftxc, 4358 "Link XOFF Transmitted"); 4359 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "xoff_recvd", 4360 CTLFLAG_RD, &stats->lxoffrxc, 4361 "Link XOFF Received"); 4362 4363 /* Packet Reception Stats */ 4364 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "total_octets_rcvd", 4365 CTLFLAG_RD, &stats->tor, 4366 "Total Octets Received"); 4367 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "good_octets_rcvd", 4368 CTLFLAG_RD, &stats->gorc, 4369 "Good Octets Received"); 4370 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "total_pkts_rcvd", 4371 CTLFLAG_RD, &stats->tpr, 4372 "Total Packets Received"); 4373 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "good_pkts_rcvd", 4374 CTLFLAG_RD, &stats->gprc, 4375 "Good Packets Received"); 4376 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "mcast_pkts_rcvd", 4377 CTLFLAG_RD, &stats->mprc, 4378 "Multicast Packets Received"); 4379 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "bcast_pkts_rcvd", 4380 CTLFLAG_RD, &stats->bprc, 4381 "Broadcast Packets Received"); 4382 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "rx_frames_64", 4383 CTLFLAG_RD, &stats->prc64, 4384 "64 byte frames received "); 4385 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "rx_frames_65_127", 4386 CTLFLAG_RD, &stats->prc127, 4387 "65-127 byte frames received"); 4388 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "rx_frames_128_255", 4389 CTLFLAG_RD, &stats->prc255, 4390 "128-255 byte frames received"); 4391 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "rx_frames_256_511", 4392 CTLFLAG_RD, &stats->prc511, 4393 "256-511 byte frames received"); 4394 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "rx_frames_512_1023", 4395 CTLFLAG_RD, &stats->prc1023, 4396 "512-1023 byte frames received"); 4397 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "rx_frames_1024_1522", 4398 CTLFLAG_RD, &stats->prc1522, 4399 "1023-1522 byte frames received"); 4400 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "recv_undersized", 4401 CTLFLAG_RD, &stats->ruc, 4402 "Receive Undersized"); 4403 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "recv_fragmented", 4404 CTLFLAG_RD, &stats->rfc, 4405 "Fragmented Packets Received "); 4406 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "recv_oversized", 4407 CTLFLAG_RD, &stats->roc, 4408 "Oversized Packets Received"); 4409 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "recv_jabberd", 4410 CTLFLAG_RD, &stats->rjc, 4411 "Received Jabber"); 4412 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "management_pkts_rcvd", 4413 CTLFLAG_RD, &stats->mngprc, 4414 "Management Packets Received"); 4415 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "management_pkts_drpd", 4416 CTLFLAG_RD, &stats->mngptc, 4417 "Management Packets Dropped"); 4418 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "checksum_errs", 4419 CTLFLAG_RD, &stats->xec, 4420 "Checksum Errors"); 4421 4422 /* Packet Transmission Stats */ 4423 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "good_octets_txd", 4424 CTLFLAG_RD, &stats->gotc, 4425 "Good Octets Transmitted"); 4426 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "total_pkts_txd", 4427 CTLFLAG_RD, &stats->tpt, 4428 "Total Packets Transmitted"); 4429 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "good_pkts_txd", 4430 CTLFLAG_RD, &stats->gptc, 4431 "Good Packets Transmitted"); 4432 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "bcast_pkts_txd", 4433 CTLFLAG_RD, &stats->bptc, 4434 "Broadcast Packets Transmitted"); 4435 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "mcast_pkts_txd", 4436 CTLFLAG_RD, &stats->mptc, 4437 "Multicast Packets Transmitted"); 4438 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "management_pkts_txd", 4439 CTLFLAG_RD, &stats->mngptc, 4440 "Management Packets Transmitted"); 4441 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "tx_frames_64", 4442 CTLFLAG_RD, &stats->ptc64, 4443 "64 byte frames transmitted "); 4444 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "tx_frames_65_127", 4445 CTLFLAG_RD, &stats->ptc127, 4446 "65-127 byte frames transmitted"); 4447 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "tx_frames_128_255", 4448 CTLFLAG_RD, &stats->ptc255, 4449 "128-255 byte frames transmitted"); 4450 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "tx_frames_256_511", 4451 CTLFLAG_RD, &stats->ptc511, 4452 "256-511 byte frames transmitted"); 4453 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "tx_frames_512_1023", 4454 CTLFLAG_RD, &stats->ptc1023, 4455 "512-1023 byte frames transmitted"); 4456 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, "tx_frames_1024_1522", 4457 CTLFLAG_RD, &stats->ptc1522, 4458 "1024-1522 byte frames transmitted"); 4459 } 4460 4461 /* 4462 ** Set flow control using sysctl: 4463 ** Flow control values: 4464 ** 0 - off 4465 ** 1 - rx pause 4466 ** 2 - tx pause 4467 ** 3 - full 4468 */ 4469 static int 4470 ixgbe_set_flowcntl(SYSCTL_HANDLER_ARGS) 4471 { 4472 int error, last; 4473 struct adapter *adapter = (struct adapter *) arg1; 4474 4475 last = adapter->fc; 4476 error = sysctl_handle_int(oidp, &adapter->fc, 0, req); 4477 if ((error) || (req->newptr == NULL)) 4478 return (error); 4479 4480 /* Don't bother if it's not changed */ 4481 if (adapter->fc == last) 4482 return (0); 4483 4484 switch (adapter->fc) { 4485 case ixgbe_fc_rx_pause: 4486 case ixgbe_fc_tx_pause: 4487 case ixgbe_fc_full: 4488 adapter->hw.fc.requested_mode = adapter->fc; 4489 if (adapter->num_queues > 1) 4490 ixgbe_disable_rx_drop(adapter); 4491 break; 4492 case ixgbe_fc_none: 4493 adapter->hw.fc.requested_mode = ixgbe_fc_none; 4494 if (adapter->num_queues > 1) 4495 ixgbe_enable_rx_drop(adapter); 4496 break; 4497 default: 4498 adapter->fc = last; 4499 return (EINVAL); 4500 } 4501 /* Don't autoneg if forcing a value */ 4502 adapter->hw.fc.disable_fc_autoneg = TRUE; 4503 ixgbe_fc_enable(&adapter->hw); 4504 return error; 4505 } 4506 4507 /* 4508 ** Control advertised link speed: 4509 ** Flags: 4510 ** 0x1 - advertise 100 Mb 4511 ** 0x2 - advertise 1G 4512 ** 0x4 - advertise 10G 4513 */ 4514 static int 4515 ixgbe_set_advertise(SYSCTL_HANDLER_ARGS) 4516 { 4517 int error = 0, requested; 4518 struct adapter *adapter; 4519 device_t dev; 4520 struct ixgbe_hw *hw; 4521 ixgbe_link_speed speed = 0; 4522 4523 adapter = (struct adapter *) arg1; 4524 dev = adapter->dev; 4525 hw = &adapter->hw; 4526 4527 requested = adapter->advertise; 4528 error = sysctl_handle_int(oidp, &requested, 0, req); 4529 if ((error) || (req->newptr == NULL)) 4530 return (error); 4531 4532 /* Checks to validate new value */ 4533 if (adapter->advertise == requested) /* no change */ 4534 return (0); 4535 4536 if (!((hw->phy.media_type == ixgbe_media_type_copper) || 4537 (hw->phy.multispeed_fiber))) { 4538 device_printf(dev, 4539 "Advertised speed can only be set on copper or " 4540 "multispeed fiber media types.\n"); 4541 return (EINVAL); 4542 } 4543 4544 if (requested < 0x1 || requested > 0x7) { 4545 device_printf(dev, 4546 "Invalid advertised speed; valid modes are 0x1 through 0x7\n"); 4547 return (EINVAL); 4548 } 4549 4550 if ((requested & 0x1) 4551 && (hw->mac.type != ixgbe_mac_X540) 4552 && (hw->mac.type != ixgbe_mac_X550)) { 4553 device_printf(dev, "Set Advertise: 100Mb on X540/X550 only\n"); 4554 return (EINVAL); 4555 } 4556 4557 /* Set new value and report new advertised mode */ 4558 if (requested & 0x1) 4559 speed |= IXGBE_LINK_SPEED_100_FULL; 4560 if (requested & 0x2) 4561 speed |= IXGBE_LINK_SPEED_1GB_FULL; 4562 if (requested & 0x4) 4563 speed |= IXGBE_LINK_SPEED_10GB_FULL; 4564 4565 hw->mac.autotry_restart = TRUE; 4566 hw->mac.ops.setup_link(hw, speed, TRUE); 4567 adapter->advertise = requested; 4568 4569 return (error); 4570 } 4571 4572 /* 4573 * The following two sysctls are for X550 BaseT devices; 4574 * they deal with the external PHY used in them. 4575 */ 4576 static int 4577 ixgbe_sysctl_phy_temp(SYSCTL_HANDLER_ARGS) 4578 { 4579 struct adapter *adapter = (struct adapter *) arg1; 4580 struct ixgbe_hw *hw = &adapter->hw; 4581 u16 reg; 4582 4583 if (hw->device_id != IXGBE_DEV_ID_X550EM_X_10G_T) { 4584 device_printf(adapter->dev, 4585 "Device has no supported external thermal sensor.\n"); 4586 return (ENODEV); 4587 } 4588 4589 if (hw->phy.ops.read_reg(hw, IXGBE_PHY_CURRENT_TEMP, 4590 IXGBE_MDIO_VENDOR_SPECIFIC_1_DEV_TYPE, 4591 ®)) { 4592 device_printf(adapter->dev, 4593 "Error reading from PHY's current temperature register\n"); 4594 return (EAGAIN); 4595 } 4596 4597 /* Shift temp for output */ 4598 reg = reg >> 8; 4599 4600 return (sysctl_handle_int(oidp, NULL, reg, req)); 4601 } 4602 4603 /* 4604 * Reports whether the current PHY temperature is over 4605 * the overtemp threshold. 4606 * - This is reported directly from the PHY 4607 */ 4608 static int 4609 ixgbe_sysctl_phy_overtemp_occurred(SYSCTL_HANDLER_ARGS) 4610 { 4611 struct adapter *adapter = (struct adapter *) arg1; 4612 struct ixgbe_hw *hw = &adapter->hw; 4613 u16 reg; 4614 4615 if (hw->device_id != IXGBE_DEV_ID_X550EM_X_10G_T) { 4616 device_printf(adapter->dev, 4617 "Device has no supported external thermal sensor.\n"); 4618 return (ENODEV); 4619 } 4620 4621 if (hw->phy.ops.read_reg(hw, IXGBE_PHY_OVERTEMP_STATUS, 4622 IXGBE_MDIO_VENDOR_SPECIFIC_1_DEV_TYPE, 4623 ®)) { 4624 device_printf(adapter->dev, 4625 "Error reading from PHY's temperature status register\n"); 4626 return (EAGAIN); 4627 } 4628 4629 /* Get occurrence bit */ 4630 reg = !!(reg & 0x4000); 4631 return (sysctl_handle_int(oidp, 0, reg, req)); 4632 } 4633 4634 /* 4635 ** Thermal Shutdown Trigger (internal MAC) 4636 ** - Set this to 1 to cause an overtemp event to occur 4637 */ 4638 static int 4639 ixgbe_sysctl_thermal_test(SYSCTL_HANDLER_ARGS) 4640 { 4641 struct adapter *adapter = (struct adapter *) arg1; 4642 struct ixgbe_hw *hw = &adapter->hw; 4643 int error, fire = 0; 4644 4645 error = sysctl_handle_int(oidp, &fire, 0, req); 4646 if ((error) || (req->newptr == NULL)) 4647 return (error); 4648 4649 if (fire) { 4650 u32 reg = IXGBE_READ_REG(hw, IXGBE_EICS); 4651 reg |= IXGBE_EICR_TS; 4652 IXGBE_WRITE_REG(hw, IXGBE_EICS, reg); 4653 } 4654 4655 return (0); 4656 } 4657 4658 /* 4659 ** Manage DMA Coalescing. 4660 ** Control values: 4661 ** 0/1 - off / on (use default value of 1000) 4662 ** 4663 ** Legal timer values are: 4664 ** 50,100,250,500,1000,2000,5000,10000 4665 ** 4666 ** Turning off interrupt moderation will also turn this off. 4667 */ 4668 static int 4669 ixgbe_sysctl_dmac(SYSCTL_HANDLER_ARGS) 4670 { 4671 struct adapter *adapter = (struct adapter *) arg1; 4672 struct ixgbe_hw *hw = &adapter->hw; 4673 struct ifnet *ifp = adapter->ifp; 4674 int error; 4675 u16 oldval; 4676 4677 oldval = adapter->dmac; 4678 error = sysctl_handle_int(oidp, &adapter->dmac, 0, req); 4679 if ((error) || (req->newptr == NULL)) 4680 return (error); 4681 4682 switch (hw->mac.type) { 4683 case ixgbe_mac_X550: 4684 case ixgbe_mac_X550EM_x: 4685 break; 4686 default: 4687 device_printf(adapter->dev, 4688 "DMA Coalescing is only supported on X550 devices\n"); 4689 return (ENODEV); 4690 } 4691 4692 switch (adapter->dmac) { 4693 case 0: 4694 /* Disabled */ 4695 break; 4696 case 1: /* Enable and use default */ 4697 adapter->dmac = 1000; 4698 break; 4699 case 50: 4700 case 100: 4701 case 250: 4702 case 500: 4703 case 1000: 4704 case 2000: 4705 case 5000: 4706 case 10000: 4707 /* Legal values - allow */ 4708 break; 4709 default: 4710 /* Do nothing, illegal value */ 4711 adapter->dmac = oldval; 4712 return (EINVAL); 4713 } 4714 4715 /* Re-initialize hardware if it's already running */ 4716 if (ifp->if_drv_flags & IFF_DRV_RUNNING) 4717 ixgbe_init(adapter); 4718 4719 return (0); 4720 } 4721 4722 /* 4723 * Sysctl to enable/disable the WoL capability, if supported by the adapter. 4724 * Values: 4725 * 0 - disabled 4726 * 1 - enabled 4727 */ 4728 static int 4729 ixgbe_sysctl_wol_enable(SYSCTL_HANDLER_ARGS) 4730 { 4731 struct adapter *adapter = (struct adapter *) arg1; 4732 struct ixgbe_hw *hw = &adapter->hw; 4733 int new_wol_enabled; 4734 int error = 0; 4735 4736 new_wol_enabled = hw->wol_enabled; 4737 error = sysctl_handle_int(oidp, &new_wol_enabled, 0, req); 4738 if ((error) || (req->newptr == NULL)) 4739 return (error); 4740 if (new_wol_enabled == hw->wol_enabled) 4741 return (0); 4742 4743 if (new_wol_enabled > 0 && !adapter->wol_support) 4744 return (ENODEV); 4745 else 4746 hw->wol_enabled = !!(new_wol_enabled); 4747 4748 return (0); 4749 } 4750 4751 /* 4752 * Sysctl to enable/disable the Energy Efficient Ethernet capability, 4753 * if supported by the adapter. 4754 * Values: 4755 * 0 - disabled 4756 * 1 - enabled 4757 */ 4758 static int 4759 ixgbe_sysctl_eee_enable(SYSCTL_HANDLER_ARGS) 4760 { 4761 struct adapter *adapter = (struct adapter *) arg1; 4762 struct ixgbe_hw *hw = &adapter->hw; 4763 struct ifnet *ifp = adapter->ifp; 4764 int new_eee_enabled, error = 0; 4765 4766 new_eee_enabled = adapter->eee_enabled; 4767 error = sysctl_handle_int(oidp, &new_eee_enabled, 0, req); 4768 if ((error) || (req->newptr == NULL)) 4769 return (error); 4770 if (new_eee_enabled == adapter->eee_enabled) 4771 return (0); 4772 4773 if (new_eee_enabled > 0 && !hw->mac.ops.setup_eee) 4774 return (ENODEV); 4775 else 4776 adapter->eee_enabled = !!(new_eee_enabled); 4777 4778 /* Re-initialize hardware if it's already running */ 4779 if (ifp->if_drv_flags & IFF_DRV_RUNNING) 4780 ixgbe_init(adapter); 4781 4782 return (0); 4783 } 4784 4785 /* 4786 * Read-only sysctl indicating whether EEE support was negotiated 4787 * on the link. 4788 */ 4789 static int 4790 ixgbe_sysctl_eee_negotiated(SYSCTL_HANDLER_ARGS) 4791 { 4792 struct adapter *adapter = (struct adapter *) arg1; 4793 struct ixgbe_hw *hw = &adapter->hw; 4794 bool status; 4795 4796 status = !!(IXGBE_READ_REG(hw, IXGBE_EEE_STAT) & IXGBE_EEE_STAT_NEG); 4797 4798 return (sysctl_handle_int(oidp, 0, status, req)); 4799 } 4800 4801 /* 4802 * Read-only sysctl indicating whether RX Link is in LPI state. 4803 */ 4804 static int 4805 ixgbe_sysctl_eee_rx_lpi_status(SYSCTL_HANDLER_ARGS) 4806 { 4807 struct adapter *adapter = (struct adapter *) arg1; 4808 struct ixgbe_hw *hw = &adapter->hw; 4809 bool status; 4810 4811 status = !!(IXGBE_READ_REG(hw, IXGBE_EEE_STAT) & 4812 IXGBE_EEE_RX_LPI_STATUS); 4813 4814 return (sysctl_handle_int(oidp, 0, status, req)); 4815 } 4816 4817 /* 4818 * Read-only sysctl indicating whether TX Link is in LPI state. 4819 */ 4820 static int 4821 ixgbe_sysctl_eee_tx_lpi_status(SYSCTL_HANDLER_ARGS) 4822 { 4823 struct adapter *adapter = (struct adapter *) arg1; 4824 struct ixgbe_hw *hw = &adapter->hw; 4825 bool status; 4826 4827 status = !!(IXGBE_READ_REG(hw, IXGBE_EEE_STAT) & 4828 IXGBE_EEE_TX_LPI_STATUS); 4829 4830 return (sysctl_handle_int(oidp, 0, status, req)); 4831 } 4832 4833 /* 4834 * Sysctl to enable/disable the types of packets that the 4835 * adapter will wake up on upon receipt. 4836 * WUFC - Wake Up Filter Control 4837 * Flags: 4838 * 0x1 - Link Status Change 4839 * 0x2 - Magic Packet 4840 * 0x4 - Direct Exact 4841 * 0x8 - Directed Multicast 4842 * 0x10 - Broadcast 4843 * 0x20 - ARP/IPv4 Request Packet 4844 * 0x40 - Direct IPv4 Packet 4845 * 0x80 - Direct IPv6 Packet 4846 * 4847 * Setting another flag will cause the sysctl to return an 4848 * error. 4849 */ 4850 static int 4851 ixgbe_sysctl_wufc(SYSCTL_HANDLER_ARGS) 4852 { 4853 struct adapter *adapter = (struct adapter *) arg1; 4854 int error = 0; 4855 u32 new_wufc; 4856 4857 new_wufc = adapter->wufc; 4858 4859 error = sysctl_handle_int(oidp, &new_wufc, 0, req); 4860 if ((error) || (req->newptr == NULL)) 4861 return (error); 4862 if (new_wufc == adapter->wufc) 4863 return (0); 4864 4865 if (new_wufc & 0xffffff00) 4866 return (EINVAL); 4867 else { 4868 new_wufc &= 0xff; 4869 new_wufc |= (0xffffff & adapter->wufc); 4870 adapter->wufc = new_wufc; 4871 } 4872 4873 return (0); 4874 } 4875 4876 /* 4877 ** Enable the hardware to drop packets when the buffer is 4878 ** full. This is useful when multiqueue,so that no single 4879 ** queue being full stalls the entire RX engine. We only 4880 ** enable this when Multiqueue AND when Flow Control is 4881 ** disabled. 4882 */ 4883 static void 4884 ixgbe_enable_rx_drop(struct adapter *adapter) 4885 { 4886 struct ixgbe_hw *hw = &adapter->hw; 4887 4888 for (int i = 0; i < adapter->num_queues; i++) { 4889 struct rx_ring *rxr = &adapter->rx_rings[i]; 4890 u32 srrctl = IXGBE_READ_REG(hw, IXGBE_SRRCTL(rxr->me)); 4891 srrctl |= IXGBE_SRRCTL_DROP_EN; 4892 IXGBE_WRITE_REG(hw, IXGBE_SRRCTL(rxr->me), srrctl); 4893 } 4894 #ifdef PCI_IOV 4895 /* enable drop for each vf */ 4896 for (int i = 0; i < adapter->num_vfs; i++) { 4897 IXGBE_WRITE_REG(hw, IXGBE_QDE, 4898 (IXGBE_QDE_WRITE | (i << IXGBE_QDE_IDX_SHIFT) | 4899 IXGBE_QDE_ENABLE)); 4900 } 4901 #endif 4902 } 4903 4904 static void 4905 ixgbe_disable_rx_drop(struct adapter *adapter) 4906 { 4907 struct ixgbe_hw *hw = &adapter->hw; 4908 4909 for (int i = 0; i < adapter->num_queues; i++) { 4910 struct rx_ring *rxr = &adapter->rx_rings[i]; 4911 u32 srrctl = IXGBE_READ_REG(hw, IXGBE_SRRCTL(rxr->me)); 4912 srrctl &= ~IXGBE_SRRCTL_DROP_EN; 4913 IXGBE_WRITE_REG(hw, IXGBE_SRRCTL(rxr->me), srrctl); 4914 } 4915 #ifdef PCI_IOV 4916 /* disable drop for each vf */ 4917 for (int i = 0; i < adapter->num_vfs; i++) { 4918 IXGBE_WRITE_REG(hw, IXGBE_QDE, 4919 (IXGBE_QDE_WRITE | (i << IXGBE_QDE_IDX_SHIFT))); 4920 } 4921 #endif 4922 } 4923 4924 static void 4925 ixgbe_rearm_queues(struct adapter *adapter, u64 queues) 4926 { 4927 u32 mask; 4928 4929 switch (adapter->hw.mac.type) { 4930 case ixgbe_mac_82598EB: 4931 mask = (IXGBE_EIMS_RTX_QUEUE & queues); 4932 IXGBE_WRITE_REG(&adapter->hw, IXGBE_EICS, mask); 4933 break; 4934 case ixgbe_mac_82599EB: 4935 case ixgbe_mac_X540: 4936 case ixgbe_mac_X550: 4937 case ixgbe_mac_X550EM_x: 4938 mask = (queues & 0xFFFFFFFF); 4939 IXGBE_WRITE_REG(&adapter->hw, IXGBE_EICS_EX(0), mask); 4940 mask = (queues >> 32); 4941 IXGBE_WRITE_REG(&adapter->hw, IXGBE_EICS_EX(1), mask); 4942 break; 4943 default: 4944 break; 4945 } 4946 } 4947 4948 #ifdef PCI_IOV 4949 4950 /* 4951 ** Support functions for SRIOV/VF management 4952 */ 4953 4954 static void 4955 ixgbe_ping_all_vfs(struct adapter *adapter) 4956 { 4957 struct ixgbe_vf *vf; 4958 4959 for (int i = 0; i < adapter->num_vfs; i++) { 4960 vf = &adapter->vfs[i]; 4961 if (vf->flags & IXGBE_VF_ACTIVE) 4962 ixgbe_send_vf_msg(adapter, vf, IXGBE_PF_CONTROL_MSG); 4963 } 4964 } 4965 4966 4967 static void 4968 ixgbe_vf_set_default_vlan(struct adapter *adapter, struct ixgbe_vf *vf, 4969 uint16_t tag) 4970 { 4971 struct ixgbe_hw *hw; 4972 uint32_t vmolr, vmvir; 4973 4974 hw = &adapter->hw; 4975 4976 vf->vlan_tag = tag; 4977 4978 vmolr = IXGBE_READ_REG(hw, IXGBE_VMOLR(vf->pool)); 4979 4980 /* Do not receive packets that pass inexact filters. */ 4981 vmolr &= ~(IXGBE_VMOLR_ROMPE | IXGBE_VMOLR_ROPE); 4982 4983 /* Disable Multicast Promicuous Mode. */ 4984 vmolr &= ~IXGBE_VMOLR_MPE; 4985 4986 /* Accept broadcasts. */ 4987 vmolr |= IXGBE_VMOLR_BAM; 4988 4989 if (tag == 0) { 4990 /* Accept non-vlan tagged traffic. */ 4991 //vmolr |= IXGBE_VMOLR_AUPE; 4992 4993 /* Allow VM to tag outgoing traffic; no default tag. */ 4994 vmvir = 0; 4995 } else { 4996 /* Require vlan-tagged traffic. */ 4997 vmolr &= ~IXGBE_VMOLR_AUPE; 4998 4999 /* Tag all traffic with provided vlan tag. */ 5000 vmvir = (tag | IXGBE_VMVIR_VLANA_DEFAULT); 5001 } 5002 IXGBE_WRITE_REG(hw, IXGBE_VMOLR(vf->pool), vmolr); 5003 IXGBE_WRITE_REG(hw, IXGBE_VMVIR(vf->pool), vmvir); 5004 } 5005 5006 5007 static boolean_t 5008 ixgbe_vf_frame_size_compatible(struct adapter *adapter, struct ixgbe_vf *vf) 5009 { 5010 5011 /* 5012 * Frame size compatibility between PF and VF is only a problem on 5013 * 82599-based cards. X540 and later support any combination of jumbo 5014 * frames on PFs and VFs. 5015 */ 5016 if (adapter->hw.mac.type != ixgbe_mac_82599EB) 5017 return (TRUE); 5018 5019 switch (vf->api_ver) { 5020 case IXGBE_API_VER_1_0: 5021 case IXGBE_API_VER_UNKNOWN: 5022 /* 5023 * On legacy (1.0 and older) VF versions, we don't support jumbo 5024 * frames on either the PF or the VF. 5025 */ 5026 if (adapter->max_frame_size > ETHER_MAX_LEN || 5027 vf->max_frame_size > ETHER_MAX_LEN) 5028 return (FALSE); 5029 5030 return (TRUE); 5031 5032 break; 5033 case IXGBE_API_VER_1_1: 5034 default: 5035 /* 5036 * 1.1 or later VF versions always work if they aren't using 5037 * jumbo frames. 5038 */ 5039 if (vf->max_frame_size <= ETHER_MAX_LEN) 5040 return (TRUE); 5041 5042 /* 5043 * Jumbo frames only work with VFs if the PF is also using jumbo 5044 * frames. 5045 */ 5046 if (adapter->max_frame_size <= ETHER_MAX_LEN) 5047 return (TRUE); 5048 5049 return (FALSE); 5050 5051 } 5052 } 5053 5054 5055 static void 5056 ixgbe_process_vf_reset(struct adapter *adapter, struct ixgbe_vf *vf) 5057 { 5058 ixgbe_vf_set_default_vlan(adapter, vf, vf->default_vlan); 5059 5060 // XXX clear multicast addresses 5061 5062 ixgbe_clear_rar(&adapter->hw, vf->rar_index); 5063 5064 vf->api_ver = IXGBE_API_VER_UNKNOWN; 5065 } 5066 5067 5068 static void 5069 ixgbe_vf_enable_transmit(struct adapter *adapter, struct ixgbe_vf *vf) 5070 { 5071 struct ixgbe_hw *hw; 5072 uint32_t vf_index, vfte; 5073 5074 hw = &adapter->hw; 5075 5076 vf_index = IXGBE_VF_INDEX(vf->pool); 5077 vfte = IXGBE_READ_REG(hw, IXGBE_VFTE(vf_index)); 5078 vfte |= IXGBE_VF_BIT(vf->pool); 5079 IXGBE_WRITE_REG(hw, IXGBE_VFTE(vf_index), vfte); 5080 } 5081 5082 5083 static void 5084 ixgbe_vf_enable_receive(struct adapter *adapter, struct ixgbe_vf *vf) 5085 { 5086 struct ixgbe_hw *hw; 5087 uint32_t vf_index, vfre; 5088 5089 hw = &adapter->hw; 5090 5091 vf_index = IXGBE_VF_INDEX(vf->pool); 5092 vfre = IXGBE_READ_REG(hw, IXGBE_VFRE(vf_index)); 5093 if (ixgbe_vf_frame_size_compatible(adapter, vf)) 5094 vfre |= IXGBE_VF_BIT(vf->pool); 5095 else 5096 vfre &= ~IXGBE_VF_BIT(vf->pool); 5097 IXGBE_WRITE_REG(hw, IXGBE_VFRE(vf_index), vfre); 5098 } 5099 5100 5101 static void 5102 ixgbe_vf_reset_msg(struct adapter *adapter, struct ixgbe_vf *vf, uint32_t *msg) 5103 { 5104 struct ixgbe_hw *hw; 5105 uint32_t ack; 5106 uint32_t resp[IXGBE_VF_PERMADDR_MSG_LEN]; 5107 5108 hw = &adapter->hw; 5109 5110 ixgbe_process_vf_reset(adapter, vf); 5111 5112 if (ixgbe_validate_mac_addr(vf->ether_addr) == 0) { 5113 ixgbe_set_rar(&adapter->hw, vf->rar_index, 5114 vf->ether_addr, vf->pool, TRUE); 5115 ack = IXGBE_VT_MSGTYPE_ACK; 5116 } else 5117 ack = IXGBE_VT_MSGTYPE_NACK; 5118 5119 ixgbe_vf_enable_transmit(adapter, vf); 5120 ixgbe_vf_enable_receive(adapter, vf); 5121 5122 vf->flags |= IXGBE_VF_CTS; 5123 5124 resp[0] = IXGBE_VF_RESET | ack | IXGBE_VT_MSGTYPE_CTS; 5125 bcopy(vf->ether_addr, &resp[1], ETHER_ADDR_LEN); 5126 resp[3] = hw->mac.mc_filter_type; 5127 ixgbe_write_mbx(hw, resp, IXGBE_VF_PERMADDR_MSG_LEN, vf->pool); 5128 } 5129 5130 5131 static void 5132 ixgbe_vf_set_mac(struct adapter *adapter, struct ixgbe_vf *vf, uint32_t *msg) 5133 { 5134 uint8_t *mac; 5135 5136 mac = (uint8_t*)&msg[1]; 5137 5138 /* Check that the VF has permission to change the MAC address. */ 5139 if (!(vf->flags & IXGBE_VF_CAP_MAC) && ixgbe_vf_mac_changed(vf, mac)) { 5140 ixgbe_send_vf_nack(adapter, vf, msg[0]); 5141 return; 5142 } 5143 5144 if (ixgbe_validate_mac_addr(mac) != 0) { 5145 ixgbe_send_vf_nack(adapter, vf, msg[0]); 5146 return; 5147 } 5148 5149 bcopy(mac, vf->ether_addr, ETHER_ADDR_LEN); 5150 5151 ixgbe_set_rar(&adapter->hw, vf->rar_index, vf->ether_addr, 5152 vf->pool, TRUE); 5153 5154 ixgbe_send_vf_ack(adapter, vf, msg[0]); 5155 } 5156 5157 5158 /* 5159 ** VF multicast addresses are set by using the appropriate bit in 5160 ** 1 of 128 32 bit addresses (4096 possible). 5161 */ 5162 static void 5163 ixgbe_vf_set_mc_addr(struct adapter *adapter, struct ixgbe_vf *vf, u32 *msg) 5164 { 5165 u16 *list = (u16*)&msg[1]; 5166 int entries; 5167 u32 vmolr, vec_bit, vec_reg, mta_reg; 5168 5169 entries = (msg[0] & IXGBE_VT_MSGINFO_MASK) >> IXGBE_VT_MSGINFO_SHIFT; 5170 entries = min(entries, IXGBE_MAX_VF_MC); 5171 5172 vmolr = IXGBE_READ_REG(&adapter->hw, IXGBE_VMOLR(vf->pool)); 5173 5174 vf->num_mc_hashes = entries; 5175 5176 /* Set the appropriate MTA bit */ 5177 for (int i = 0; i < entries; i++) { 5178 vf->mc_hash[i] = list[i]; 5179 vec_reg = (vf->mc_hash[i] >> 5) & 0x7F; 5180 vec_bit = vf->mc_hash[i] & 0x1F; 5181 mta_reg = IXGBE_READ_REG(&adapter->hw, IXGBE_MTA(vec_reg)); 5182 mta_reg |= (1 << vec_bit); 5183 IXGBE_WRITE_REG(&adapter->hw, IXGBE_MTA(vec_reg), mta_reg); 5184 } 5185 5186 vmolr |= IXGBE_VMOLR_ROMPE; 5187 IXGBE_WRITE_REG(&adapter->hw, IXGBE_VMOLR(vf->pool), vmolr); 5188 ixgbe_send_vf_ack(adapter, vf, msg[0]); 5189 return; 5190 } 5191 5192 5193 static void 5194 ixgbe_vf_set_vlan(struct adapter *adapter, struct ixgbe_vf *vf, uint32_t *msg) 5195 { 5196 struct ixgbe_hw *hw; 5197 int enable; 5198 uint16_t tag; 5199 5200 hw = &adapter->hw; 5201 enable = IXGBE_VT_MSGINFO(msg[0]); 5202 tag = msg[1] & IXGBE_VLVF_VLANID_MASK; 5203 5204 if (!(vf->flags & IXGBE_VF_CAP_VLAN)) { 5205 ixgbe_send_vf_nack(adapter, vf, msg[0]); 5206 return; 5207 } 5208 5209 /* It is illegal to enable vlan tag 0. */ 5210 if (tag == 0 && enable != 0){ 5211 ixgbe_send_vf_nack(adapter, vf, msg[0]); 5212 return; 5213 } 5214 5215 ixgbe_set_vfta(hw, tag, vf->pool, enable); 5216 ixgbe_send_vf_ack(adapter, vf, msg[0]); 5217 } 5218 5219 5220 static void 5221 ixgbe_vf_set_lpe(struct adapter *adapter, struct ixgbe_vf *vf, uint32_t *msg) 5222 { 5223 struct ixgbe_hw *hw; 5224 uint32_t vf_max_size, pf_max_size, mhadd; 5225 5226 hw = &adapter->hw; 5227 vf_max_size = msg[1]; 5228 5229 if (vf_max_size < ETHER_CRC_LEN) { 5230 /* We intentionally ACK invalid LPE requests. */ 5231 ixgbe_send_vf_ack(adapter, vf, msg[0]); 5232 return; 5233 } 5234 5235 vf_max_size -= ETHER_CRC_LEN; 5236 5237 if (vf_max_size > IXGBE_MAX_FRAME_SIZE) { 5238 /* We intentionally ACK invalid LPE requests. */ 5239 ixgbe_send_vf_ack(adapter, vf, msg[0]); 5240 return; 5241 } 5242 5243 vf->max_frame_size = vf_max_size; 5244 ixgbe_update_max_frame(adapter, vf->max_frame_size); 5245 5246 /* 5247 * We might have to disable reception to this VF if the frame size is 5248 * not compatible with the config on the PF. 5249 */ 5250 ixgbe_vf_enable_receive(adapter, vf); 5251 5252 mhadd = IXGBE_READ_REG(hw, IXGBE_MHADD); 5253 pf_max_size = (mhadd & IXGBE_MHADD_MFS_MASK) >> IXGBE_MHADD_MFS_SHIFT; 5254 5255 if (pf_max_size < adapter->max_frame_size) { 5256 mhadd &= ~IXGBE_MHADD_MFS_MASK; 5257 mhadd |= adapter->max_frame_size << IXGBE_MHADD_MFS_SHIFT; 5258 IXGBE_WRITE_REG(hw, IXGBE_MHADD, mhadd); 5259 } 5260 5261 ixgbe_send_vf_ack(adapter, vf, msg[0]); 5262 } 5263 5264 5265 static void 5266 ixgbe_vf_set_macvlan(struct adapter *adapter, struct ixgbe_vf *vf, 5267 uint32_t *msg) 5268 { 5269 //XXX implement this 5270 ixgbe_send_vf_nack(adapter, vf, msg[0]); 5271 } 5272 5273 5274 static void 5275 ixgbe_vf_api_negotiate(struct adapter *adapter, struct ixgbe_vf *vf, 5276 uint32_t *msg) 5277 { 5278 5279 switch (msg[1]) { 5280 case IXGBE_API_VER_1_0: 5281 case IXGBE_API_VER_1_1: 5282 vf->api_ver = msg[1]; 5283 ixgbe_send_vf_ack(adapter, vf, msg[0]); 5284 break; 5285 default: 5286 vf->api_ver = IXGBE_API_VER_UNKNOWN; 5287 ixgbe_send_vf_nack(adapter, vf, msg[0]); 5288 break; 5289 } 5290 } 5291 5292 5293 static void 5294 ixgbe_vf_get_queues(struct adapter *adapter, struct ixgbe_vf *vf, 5295 uint32_t *msg) 5296 { 5297 struct ixgbe_hw *hw; 5298 uint32_t resp[IXGBE_VF_GET_QUEUES_RESP_LEN]; 5299 int num_queues; 5300 5301 hw = &adapter->hw; 5302 5303 /* GET_QUEUES is not supported on pre-1.1 APIs. */ 5304 switch (msg[0]) { 5305 case IXGBE_API_VER_1_0: 5306 case IXGBE_API_VER_UNKNOWN: 5307 ixgbe_send_vf_nack(adapter, vf, msg[0]); 5308 return; 5309 } 5310 5311 resp[0] = IXGBE_VF_GET_QUEUES | IXGBE_VT_MSGTYPE_ACK | 5312 IXGBE_VT_MSGTYPE_CTS; 5313 5314 num_queues = ixgbe_vf_queues(ixgbe_get_iov_mode(adapter)); 5315 resp[IXGBE_VF_TX_QUEUES] = num_queues; 5316 resp[IXGBE_VF_RX_QUEUES] = num_queues; 5317 resp[IXGBE_VF_TRANS_VLAN] = (vf->default_vlan != 0); 5318 resp[IXGBE_VF_DEF_QUEUE] = 0; 5319 5320 ixgbe_write_mbx(hw, resp, IXGBE_VF_GET_QUEUES_RESP_LEN, vf->pool); 5321 } 5322 5323 5324 static void 5325 ixgbe_process_vf_msg(struct adapter *adapter, struct ixgbe_vf *vf) 5326 { 5327 struct ixgbe_hw *hw; 5328 uint32_t msg[IXGBE_VFMAILBOX_SIZE]; 5329 int error; 5330 5331 hw = &adapter->hw; 5332 5333 error = ixgbe_read_mbx(hw, msg, IXGBE_VFMAILBOX_SIZE, vf->pool); 5334 5335 if (error != 0) 5336 return; 5337 5338 CTR3(KTR_MALLOC, "%s: received msg %x from %d", 5339 adapter->ifp->if_xname, msg[0], vf->pool); 5340 if (msg[0] == IXGBE_VF_RESET) { 5341 ixgbe_vf_reset_msg(adapter, vf, msg); 5342 return; 5343 } 5344 5345 if (!(vf->flags & IXGBE_VF_CTS)) { 5346 ixgbe_send_vf_nack(adapter, vf, msg[0]); 5347 return; 5348 } 5349 5350 switch (msg[0] & IXGBE_VT_MSG_MASK) { 5351 case IXGBE_VF_SET_MAC_ADDR: 5352 ixgbe_vf_set_mac(adapter, vf, msg); 5353 break; 5354 case IXGBE_VF_SET_MULTICAST: 5355 ixgbe_vf_set_mc_addr(adapter, vf, msg); 5356 break; 5357 case IXGBE_VF_SET_VLAN: 5358 ixgbe_vf_set_vlan(adapter, vf, msg); 5359 break; 5360 case IXGBE_VF_SET_LPE: 5361 ixgbe_vf_set_lpe(adapter, vf, msg); 5362 break; 5363 case IXGBE_VF_SET_MACVLAN: 5364 ixgbe_vf_set_macvlan(adapter, vf, msg); 5365 break; 5366 case IXGBE_VF_API_NEGOTIATE: 5367 ixgbe_vf_api_negotiate(adapter, vf, msg); 5368 break; 5369 case IXGBE_VF_GET_QUEUES: 5370 ixgbe_vf_get_queues(adapter, vf, msg); 5371 break; 5372 default: 5373 ixgbe_send_vf_nack(adapter, vf, msg[0]); 5374 } 5375 } 5376 5377 5378 /* 5379 * Tasklet for handling VF -> PF mailbox messages. 5380 */ 5381 static void 5382 ixgbe_handle_mbx(void *context, int pending) 5383 { 5384 struct adapter *adapter; 5385 struct ixgbe_hw *hw; 5386 struct ixgbe_vf *vf; 5387 int i; 5388 5389 adapter = context; 5390 hw = &adapter->hw; 5391 5392 IXGBE_CORE_LOCK(adapter); 5393 for (i = 0; i < adapter->num_vfs; i++) { 5394 vf = &adapter->vfs[i]; 5395 5396 if (vf->flags & IXGBE_VF_ACTIVE) { 5397 if (ixgbe_check_for_rst(hw, vf->pool) == 0) 5398 ixgbe_process_vf_reset(adapter, vf); 5399 5400 if (ixgbe_check_for_msg(hw, vf->pool) == 0) 5401 ixgbe_process_vf_msg(adapter, vf); 5402 5403 if (ixgbe_check_for_ack(hw, vf->pool) == 0) 5404 ixgbe_process_vf_ack(adapter, vf); 5405 } 5406 } 5407 IXGBE_CORE_UNLOCK(adapter); 5408 } 5409 5410 5411 static int 5412 ixgbe_init_iov(device_t dev, u16 num_vfs, const nvlist_t *config) 5413 { 5414 struct adapter *adapter; 5415 enum ixgbe_iov_mode mode; 5416 5417 adapter = device_get_softc(dev); 5418 adapter->num_vfs = num_vfs; 5419 mode = ixgbe_get_iov_mode(adapter); 5420 5421 if (num_vfs > ixgbe_max_vfs(mode)) { 5422 adapter->num_vfs = 0; 5423 return (ENOSPC); 5424 } 5425 5426 IXGBE_CORE_LOCK(adapter); 5427 5428 adapter->vfs = malloc(sizeof(*adapter->vfs) * num_vfs, M_IXGBE, 5429 M_NOWAIT | M_ZERO); 5430 5431 if (adapter->vfs == NULL) { 5432 adapter->num_vfs = 0; 5433 IXGBE_CORE_UNLOCK(adapter); 5434 return (ENOMEM); 5435 } 5436 5437 ixgbe_init_locked(adapter); 5438 5439 IXGBE_CORE_UNLOCK(adapter); 5440 5441 return (0); 5442 } 5443 5444 5445 static void 5446 ixgbe_uninit_iov(device_t dev) 5447 { 5448 struct ixgbe_hw *hw; 5449 struct adapter *adapter; 5450 uint32_t pf_reg, vf_reg; 5451 5452 adapter = device_get_softc(dev); 5453 hw = &adapter->hw; 5454 5455 IXGBE_CORE_LOCK(adapter); 5456 5457 /* Enable rx/tx for the PF and disable it for all VFs. */ 5458 pf_reg = IXGBE_VF_INDEX(adapter->pool); 5459 IXGBE_WRITE_REG(hw, IXGBE_VFRE(pf_reg), 5460 IXGBE_VF_BIT(adapter->pool)); 5461 IXGBE_WRITE_REG(hw, IXGBE_VFTE(pf_reg), 5462 IXGBE_VF_BIT(adapter->pool)); 5463 5464 if (pf_reg == 0) 5465 vf_reg = 1; 5466 else 5467 vf_reg = 0; 5468 IXGBE_WRITE_REG(hw, IXGBE_VFRE(vf_reg), 0); 5469 IXGBE_WRITE_REG(hw, IXGBE_VFTE(vf_reg), 0); 5470 5471 IXGBE_WRITE_REG(hw, IXGBE_VT_CTL, 0); 5472 5473 free(adapter->vfs, M_IXGBE); 5474 adapter->vfs = NULL; 5475 adapter->num_vfs = 0; 5476 5477 IXGBE_CORE_UNLOCK(adapter); 5478 } 5479 5480 5481 static void 5482 ixgbe_initialize_iov(struct adapter *adapter) 5483 { 5484 struct ixgbe_hw *hw = &adapter->hw; 5485 uint32_t mrqc, mtqc, vt_ctl, vf_reg, gcr_ext, gpie; 5486 enum ixgbe_iov_mode mode; 5487 int i; 5488 5489 mode = ixgbe_get_iov_mode(adapter); 5490 if (mode == IXGBE_NO_VM) 5491 return; 5492 5493 IXGBE_CORE_LOCK_ASSERT(adapter); 5494 5495 mrqc = IXGBE_READ_REG(hw, IXGBE_MRQC); 5496 mrqc &= ~IXGBE_MRQC_MRQE_MASK; 5497 5498 switch (mode) { 5499 case IXGBE_64_VM: 5500 mrqc |= IXGBE_MRQC_VMDQRSS64EN; 5501 break; 5502 case IXGBE_32_VM: 5503 mrqc |= IXGBE_MRQC_VMDQRSS32EN; 5504 break; 5505 default: 5506 panic("Unexpected SR-IOV mode %d", mode); 5507 } 5508 IXGBE_WRITE_REG(hw, IXGBE_MRQC, mrqc); 5509 5510 mtqc = IXGBE_MTQC_VT_ENA; 5511 switch (mode) { 5512 case IXGBE_64_VM: 5513 mtqc |= IXGBE_MTQC_64VF; 5514 break; 5515 case IXGBE_32_VM: 5516 mtqc |= IXGBE_MTQC_32VF; 5517 break; 5518 default: 5519 panic("Unexpected SR-IOV mode %d", mode); 5520 } 5521 IXGBE_WRITE_REG(hw, IXGBE_MTQC, mtqc); 5522 5523 5524 gcr_ext = IXGBE_READ_REG(hw, IXGBE_GCR_EXT); 5525 gcr_ext |= IXGBE_GCR_EXT_MSIX_EN; 5526 gcr_ext &= ~IXGBE_GCR_EXT_VT_MODE_MASK; 5527 switch (mode) { 5528 case IXGBE_64_VM: 5529 gcr_ext |= IXGBE_GCR_EXT_VT_MODE_64; 5530 break; 5531 case IXGBE_32_VM: 5532 gcr_ext |= IXGBE_GCR_EXT_VT_MODE_32; 5533 break; 5534 default: 5535 panic("Unexpected SR-IOV mode %d", mode); 5536 } 5537 IXGBE_WRITE_REG(hw, IXGBE_GCR_EXT, gcr_ext); 5538 5539 5540 gpie = IXGBE_READ_REG(hw, IXGBE_GPIE); 5541 gcr_ext &= ~IXGBE_GPIE_VTMODE_MASK; 5542 switch (mode) { 5543 case IXGBE_64_VM: 5544 gpie |= IXGBE_GPIE_VTMODE_64; 5545 break; 5546 case IXGBE_32_VM: 5547 gpie |= IXGBE_GPIE_VTMODE_32; 5548 break; 5549 default: 5550 panic("Unexpected SR-IOV mode %d", mode); 5551 } 5552 IXGBE_WRITE_REG(hw, IXGBE_GPIE, gpie); 5553 5554 /* Enable rx/tx for the PF. */ 5555 vf_reg = IXGBE_VF_INDEX(adapter->pool); 5556 IXGBE_WRITE_REG(hw, IXGBE_VFRE(vf_reg), 5557 IXGBE_VF_BIT(adapter->pool)); 5558 IXGBE_WRITE_REG(hw, IXGBE_VFTE(vf_reg), 5559 IXGBE_VF_BIT(adapter->pool)); 5560 5561 /* Allow VM-to-VM communication. */ 5562 IXGBE_WRITE_REG(hw, IXGBE_PFDTXGSWC, IXGBE_PFDTXGSWC_VT_LBEN); 5563 5564 vt_ctl = IXGBE_VT_CTL_VT_ENABLE | IXGBE_VT_CTL_REPLEN; 5565 vt_ctl |= (adapter->pool << IXGBE_VT_CTL_POOL_SHIFT); 5566 IXGBE_WRITE_REG(hw, IXGBE_VT_CTL, vt_ctl); 5567 5568 for (i = 0; i < adapter->num_vfs; i++) 5569 ixgbe_init_vf(adapter, &adapter->vfs[i]); 5570 } 5571 5572 5573 /* 5574 ** Check the max frame setting of all active VF's 5575 */ 5576 static void 5577 ixgbe_recalculate_max_frame(struct adapter *adapter) 5578 { 5579 struct ixgbe_vf *vf; 5580 5581 IXGBE_CORE_LOCK_ASSERT(adapter); 5582 5583 for (int i = 0; i < adapter->num_vfs; i++) { 5584 vf = &adapter->vfs[i]; 5585 if (vf->flags & IXGBE_VF_ACTIVE) 5586 ixgbe_update_max_frame(adapter, vf->max_frame_size); 5587 } 5588 } 5589 5590 5591 static void 5592 ixgbe_init_vf(struct adapter *adapter, struct ixgbe_vf *vf) 5593 { 5594 struct ixgbe_hw *hw; 5595 uint32_t vf_index, pfmbimr; 5596 5597 IXGBE_CORE_LOCK_ASSERT(adapter); 5598 5599 hw = &adapter->hw; 5600 5601 if (!(vf->flags & IXGBE_VF_ACTIVE)) 5602 return; 5603 5604 vf_index = IXGBE_VF_INDEX(vf->pool); 5605 pfmbimr = IXGBE_READ_REG(hw, IXGBE_PFMBIMR(vf_index)); 5606 pfmbimr |= IXGBE_VF_BIT(vf->pool); 5607 IXGBE_WRITE_REG(hw, IXGBE_PFMBIMR(vf_index), pfmbimr); 5608 5609 ixgbe_vf_set_default_vlan(adapter, vf, vf->vlan_tag); 5610 5611 // XXX multicast addresses 5612 5613 if (ixgbe_validate_mac_addr(vf->ether_addr) == 0) { 5614 ixgbe_set_rar(&adapter->hw, vf->rar_index, 5615 vf->ether_addr, vf->pool, TRUE); 5616 } 5617 5618 ixgbe_vf_enable_transmit(adapter, vf); 5619 ixgbe_vf_enable_receive(adapter, vf); 5620 5621 ixgbe_send_vf_msg(adapter, vf, IXGBE_PF_CONTROL_MSG); 5622 } 5623 5624 static int 5625 ixgbe_add_vf(device_t dev, u16 vfnum, const nvlist_t *config) 5626 { 5627 struct adapter *adapter; 5628 struct ixgbe_vf *vf; 5629 const void *mac; 5630 5631 adapter = device_get_softc(dev); 5632 5633 KASSERT(vfnum < adapter->num_vfs, ("VF index %d is out of range %d", 5634 vfnum, adapter->num_vfs)); 5635 5636 IXGBE_CORE_LOCK(adapter); 5637 vf = &adapter->vfs[vfnum]; 5638 vf->pool= vfnum; 5639 5640 /* RAR[0] is used by the PF so use vfnum + 1 for VF RAR. */ 5641 vf->rar_index = vfnum + 1; 5642 vf->default_vlan = 0; 5643 vf->max_frame_size = ETHER_MAX_LEN; 5644 ixgbe_update_max_frame(adapter, vf->max_frame_size); 5645 5646 if (nvlist_exists_binary(config, "mac-addr")) { 5647 mac = nvlist_get_binary(config, "mac-addr", NULL); 5648 bcopy(mac, vf->ether_addr, ETHER_ADDR_LEN); 5649 if (nvlist_get_bool(config, "allow-set-mac")) 5650 vf->flags |= IXGBE_VF_CAP_MAC; 5651 } else 5652 /* 5653 * If the administrator has not specified a MAC address then 5654 * we must allow the VF to choose one. 5655 */ 5656 vf->flags |= IXGBE_VF_CAP_MAC; 5657 5658 vf->flags = IXGBE_VF_ACTIVE; 5659 5660 ixgbe_init_vf(adapter, vf); 5661 IXGBE_CORE_UNLOCK(adapter); 5662 5663 return (0); 5664 } 5665 #endif /* PCI_IOV */ 5666 5667