1 /* 2 * CDDL HEADER START 3 * 4 * Copyright(c) 2007-2009 Intel Corporation. All rights reserved. 5 * The contents of this file are subject to the terms of the 6 * Common Development and Distribution License (the "License"). 7 * You may not use this file except in compliance with the License. 8 * 9 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 10 * or http://www.opensolaris.org/os/licensing. 11 * See the License for the specific language governing permissions 12 * and limitations under the License. 13 * 14 * When distributing Covered Code, include this CDDL HEADER in each 15 * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 16 * If applicable, add the following below this CDDL HEADER, with the 17 * fields enclosed by brackets "[]" replaced with your own identifying 18 * information: Portions Copyright [yyyy] [name of copyright owner] 19 * 20 * CDDL HEADER END 21 */ 22 23 /* 24 * Copyright 2009 Sun Microsystems, Inc. All rights reserved. 25 * Use is subject to license terms. 26 */ 27 28 #include "ixgbe_sw.h" 29 30 static char ident[] = "Intel 10Gb Ethernet"; 31 static char ixgbe_version[] = "ixgbe 1.1.3"; 32 33 /* 34 * Local function protoypes 35 */ 36 static int ixgbe_register_mac(ixgbe_t *); 37 static int ixgbe_identify_hardware(ixgbe_t *); 38 static int ixgbe_regs_map(ixgbe_t *); 39 static void ixgbe_init_properties(ixgbe_t *); 40 static int ixgbe_init_driver_settings(ixgbe_t *); 41 static void ixgbe_init_locks(ixgbe_t *); 42 static void ixgbe_destroy_locks(ixgbe_t *); 43 static int ixgbe_init(ixgbe_t *); 44 static int ixgbe_chip_start(ixgbe_t *); 45 static void ixgbe_chip_stop(ixgbe_t *); 46 static int ixgbe_reset(ixgbe_t *); 47 static void ixgbe_tx_clean(ixgbe_t *); 48 static boolean_t ixgbe_tx_drain(ixgbe_t *); 49 static boolean_t ixgbe_rx_drain(ixgbe_t *); 50 static int ixgbe_alloc_rings(ixgbe_t *); 51 static void ixgbe_free_rings(ixgbe_t *); 52 static int ixgbe_alloc_rx_data(ixgbe_t *); 53 static void ixgbe_free_rx_data(ixgbe_t *); 54 static void ixgbe_setup_rings(ixgbe_t *); 55 static void ixgbe_setup_rx(ixgbe_t *); 56 static void ixgbe_setup_tx(ixgbe_t *); 57 static void ixgbe_setup_rx_ring(ixgbe_rx_ring_t *); 58 static void ixgbe_setup_tx_ring(ixgbe_tx_ring_t *); 59 static void ixgbe_setup_rss(ixgbe_t *); 60 static void ixgbe_init_unicst(ixgbe_t *); 61 static int ixgbe_unicst_set(ixgbe_t *, const uint8_t *, int); 62 static int ixgbe_unicst_find(ixgbe_t *, const uint8_t *); 63 static void ixgbe_setup_multicst(ixgbe_t *); 64 static void ixgbe_get_hw_state(ixgbe_t *); 65 static void ixgbe_get_conf(ixgbe_t *); 66 static void ixgbe_init_params(ixgbe_t *); 67 static int ixgbe_get_prop(ixgbe_t *, char *, int, int, int); 68 static void ixgbe_driver_link_check(ixgbe_t *); 69 static void ixgbe_sfp_check(void *); 70 static void ixgbe_link_timer(void *); 71 static void ixgbe_local_timer(void *); 72 static void ixgbe_arm_watchdog_timer(ixgbe_t *); 73 static void ixgbe_restart_watchdog_timer(ixgbe_t *); 74 static void ixgbe_disable_adapter_interrupts(ixgbe_t *); 75 static void ixgbe_enable_adapter_interrupts(ixgbe_t *); 76 static boolean_t is_valid_mac_addr(uint8_t *); 77 static boolean_t ixgbe_stall_check(ixgbe_t *); 78 static boolean_t ixgbe_set_loopback_mode(ixgbe_t *, uint32_t); 79 static void ixgbe_set_internal_mac_loopback(ixgbe_t *); 80 static boolean_t ixgbe_find_mac_address(ixgbe_t *); 81 static int ixgbe_alloc_intrs(ixgbe_t *); 82 static int ixgbe_alloc_intr_handles(ixgbe_t *, int); 83 static int ixgbe_add_intr_handlers(ixgbe_t *); 84 static void ixgbe_map_rxring_to_vector(ixgbe_t *, int, int); 85 static void ixgbe_map_txring_to_vector(ixgbe_t *, int, int); 86 static void ixgbe_setup_ivar(ixgbe_t *, uint16_t, uint8_t, int8_t); 87 static void ixgbe_enable_ivar(ixgbe_t *, uint16_t, int8_t); 88 static void ixgbe_disable_ivar(ixgbe_t *, uint16_t, int8_t); 89 static int ixgbe_map_intrs_to_vectors(ixgbe_t *); 90 static void ixgbe_setup_adapter_vector(ixgbe_t *); 91 static void ixgbe_rem_intr_handlers(ixgbe_t *); 92 static void ixgbe_rem_intrs(ixgbe_t *); 93 static int ixgbe_enable_intrs(ixgbe_t *); 94 static int ixgbe_disable_intrs(ixgbe_t *); 95 static uint_t ixgbe_intr_legacy(void *, void *); 96 static uint_t ixgbe_intr_msi(void *, void *); 97 static uint_t ixgbe_intr_msix(void *, void *); 98 static void ixgbe_intr_rx_work(ixgbe_rx_ring_t *); 99 static void ixgbe_intr_tx_work(ixgbe_tx_ring_t *); 100 static void ixgbe_intr_other_work(ixgbe_t *, uint32_t); 101 static void ixgbe_get_driver_control(struct ixgbe_hw *); 102 static int ixgbe_addmac(void *, const uint8_t *); 103 static int ixgbe_remmac(void *, const uint8_t *); 104 static void ixgbe_release_driver_control(struct ixgbe_hw *); 105 106 static int ixgbe_attach(dev_info_t *, ddi_attach_cmd_t); 107 static int ixgbe_detach(dev_info_t *, ddi_detach_cmd_t); 108 static int ixgbe_resume(dev_info_t *); 109 static int ixgbe_suspend(dev_info_t *); 110 static void ixgbe_unconfigure(dev_info_t *, ixgbe_t *); 111 static uint8_t *ixgbe_mc_table_itr(struct ixgbe_hw *, uint8_t **, uint32_t *); 112 113 static int ixgbe_fm_error_cb(dev_info_t *dip, ddi_fm_error_t *err, 114 const void *impl_data); 115 static void ixgbe_fm_init(ixgbe_t *); 116 static void ixgbe_fm_fini(ixgbe_t *); 117 118 mac_priv_prop_t ixgbe_priv_props[] = { 119 {"_tx_copy_thresh", MAC_PROP_PERM_RW}, 120 {"_tx_recycle_thresh", MAC_PROP_PERM_RW}, 121 {"_tx_overload_thresh", MAC_PROP_PERM_RW}, 122 {"_tx_resched_thresh", MAC_PROP_PERM_RW}, 123 {"_rx_copy_thresh", MAC_PROP_PERM_RW}, 124 {"_rx_limit_per_intr", MAC_PROP_PERM_RW}, 125 {"_intr_throttling", MAC_PROP_PERM_RW}, 126 {"_adv_pause_cap", MAC_PROP_PERM_READ}, 127 {"_adv_asym_pause_cap", MAC_PROP_PERM_READ} 128 }; 129 130 #define IXGBE_MAX_PRIV_PROPS \ 131 (sizeof (ixgbe_priv_props) / sizeof (mac_priv_prop_t)) 132 133 static struct cb_ops ixgbe_cb_ops = { 134 nulldev, /* cb_open */ 135 nulldev, /* cb_close */ 136 nodev, /* cb_strategy */ 137 nodev, /* cb_print */ 138 nodev, /* cb_dump */ 139 nodev, /* cb_read */ 140 nodev, /* cb_write */ 141 nodev, /* cb_ioctl */ 142 nodev, /* cb_devmap */ 143 nodev, /* cb_mmap */ 144 nodev, /* cb_segmap */ 145 nochpoll, /* cb_chpoll */ 146 ddi_prop_op, /* cb_prop_op */ 147 NULL, /* cb_stream */ 148 D_MP | D_HOTPLUG, /* cb_flag */ 149 CB_REV, /* cb_rev */ 150 nodev, /* cb_aread */ 151 nodev /* cb_awrite */ 152 }; 153 154 static struct dev_ops ixgbe_dev_ops = { 155 DEVO_REV, /* devo_rev */ 156 0, /* devo_refcnt */ 157 NULL, /* devo_getinfo */ 158 nulldev, /* devo_identify */ 159 nulldev, /* devo_probe */ 160 ixgbe_attach, /* devo_attach */ 161 ixgbe_detach, /* devo_detach */ 162 nodev, /* devo_reset */ 163 &ixgbe_cb_ops, /* devo_cb_ops */ 164 NULL, /* devo_bus_ops */ 165 ddi_power, /* devo_power */ 166 ddi_quiesce_not_supported, /* devo_quiesce */ 167 }; 168 169 static struct modldrv ixgbe_modldrv = { 170 &mod_driverops, /* Type of module. This one is a driver */ 171 ident, /* Discription string */ 172 &ixgbe_dev_ops /* driver ops */ 173 }; 174 175 static struct modlinkage ixgbe_modlinkage = { 176 MODREV_1, &ixgbe_modldrv, NULL 177 }; 178 179 /* 180 * Access attributes for register mapping 181 */ 182 ddi_device_acc_attr_t ixgbe_regs_acc_attr = { 183 DDI_DEVICE_ATTR_V0, 184 DDI_STRUCTURE_LE_ACC, 185 DDI_STRICTORDER_ACC, 186 DDI_FLAGERR_ACC 187 }; 188 189 /* 190 * Loopback property 191 */ 192 static lb_property_t lb_normal = { 193 normal, "normal", IXGBE_LB_NONE 194 }; 195 196 static lb_property_t lb_mac = { 197 internal, "MAC", IXGBE_LB_INTERNAL_MAC 198 }; 199 200 static lb_property_t lb_external = { 201 external, "External", IXGBE_LB_EXTERNAL 202 }; 203 204 #define IXGBE_M_CALLBACK_FLAGS \ 205 (MC_IOCTL | MC_GETCAPAB | MC_SETPROP | MC_GETPROP) 206 207 static mac_callbacks_t ixgbe_m_callbacks = { 208 IXGBE_M_CALLBACK_FLAGS, 209 ixgbe_m_stat, 210 ixgbe_m_start, 211 ixgbe_m_stop, 212 ixgbe_m_promisc, 213 ixgbe_m_multicst, 214 NULL, 215 NULL, 216 ixgbe_m_ioctl, 217 ixgbe_m_getcapab, 218 NULL, 219 NULL, 220 ixgbe_m_setprop, 221 ixgbe_m_getprop 222 }; 223 224 /* 225 * Initialize capabilities of each supported adapter type 226 */ 227 static adapter_info_t ixgbe_82598eb_cap = { 228 64, /* maximum number of rx queues */ 229 1, /* minimum number of rx queues */ 230 8, /* default number of rx queues */ 231 32, /* maximum number of tx queues */ 232 1, /* minimum number of tx queues */ 233 8, /* default number of tx queues */ 234 16366, /* maximum MTU size */ 235 0xFFFF, /* maximum interrupt throttle rate */ 236 0, /* minimum interrupt throttle rate */ 237 200, /* default interrupt throttle rate */ 238 18, /* maximum total msix vectors */ 239 16, /* maximum number of ring vectors */ 240 2, /* maximum number of other vectors */ 241 IXGBE_EICR_LSC, /* "other" interrupt types handled */ 242 (IXGBE_FLAG_DCA_CAPABLE /* capability flags */ 243 | IXGBE_FLAG_RSS_CAPABLE 244 | IXGBE_FLAG_VMDQ_CAPABLE) 245 }; 246 247 static adapter_info_t ixgbe_82599eb_cap = { 248 128, /* maximum number of rx queues */ 249 1, /* minimum number of rx queues */ 250 8, /* default number of rx queues */ 251 128, /* maximum number of tx queues */ 252 1, /* minimum number of tx queues */ 253 8, /* default number of tx queues */ 254 15500, /* maximum MTU size */ 255 0xFF8, /* maximum interrupt throttle rate */ 256 0, /* minimum interrupt throttle rate */ 257 200, /* default interrupt throttle rate */ 258 64, /* maximum total msix vectors */ 259 16, /* maximum number of ring vectors */ 260 2, /* maximum number of other vectors */ 261 IXGBE_EICR_LSC, /* "other" interrupt types handled */ 262 (IXGBE_FLAG_DCA_CAPABLE /* capability flags */ 263 | IXGBE_FLAG_RSS_CAPABLE 264 | IXGBE_FLAG_VMDQ_CAPABLE) 265 }; 266 267 /* 268 * Module Initialization Functions. 269 */ 270 271 int 272 _init(void) 273 { 274 int status; 275 276 mac_init_ops(&ixgbe_dev_ops, MODULE_NAME); 277 278 status = mod_install(&ixgbe_modlinkage); 279 280 if (status != DDI_SUCCESS) { 281 mac_fini_ops(&ixgbe_dev_ops); 282 } 283 284 return (status); 285 } 286 287 int 288 _fini(void) 289 { 290 int status; 291 292 status = mod_remove(&ixgbe_modlinkage); 293 294 if (status == DDI_SUCCESS) { 295 mac_fini_ops(&ixgbe_dev_ops); 296 } 297 298 return (status); 299 } 300 301 int 302 _info(struct modinfo *modinfop) 303 { 304 int status; 305 306 status = mod_info(&ixgbe_modlinkage, modinfop); 307 308 return (status); 309 } 310 311 /* 312 * ixgbe_attach - Driver attach. 313 * 314 * This function is the device specific initialization entry 315 * point. This entry point is required and must be written. 316 * The DDI_ATTACH command must be provided in the attach entry 317 * point. When attach() is called with cmd set to DDI_ATTACH, 318 * all normal kernel services (such as kmem_alloc(9F)) are 319 * available for use by the driver. 320 * 321 * The attach() function will be called once for each instance 322 * of the device on the system with cmd set to DDI_ATTACH. 323 * Until attach() succeeds, the only driver entry points which 324 * may be called are open(9E) and getinfo(9E). 325 */ 326 static int 327 ixgbe_attach(dev_info_t *devinfo, ddi_attach_cmd_t cmd) 328 { 329 ixgbe_t *ixgbe; 330 struct ixgbe_osdep *osdep; 331 struct ixgbe_hw *hw; 332 int instance; 333 char taskqname[32]; 334 335 /* 336 * Check the command and perform corresponding operations 337 */ 338 switch (cmd) { 339 default: 340 return (DDI_FAILURE); 341 342 case DDI_RESUME: 343 return (ixgbe_resume(devinfo)); 344 345 case DDI_ATTACH: 346 break; 347 } 348 349 /* Get the device instance */ 350 instance = ddi_get_instance(devinfo); 351 352 /* Allocate memory for the instance data structure */ 353 ixgbe = kmem_zalloc(sizeof (ixgbe_t), KM_SLEEP); 354 355 ixgbe->dip = devinfo; 356 ixgbe->instance = instance; 357 358 hw = &ixgbe->hw; 359 osdep = &ixgbe->osdep; 360 hw->back = osdep; 361 osdep->ixgbe = ixgbe; 362 363 /* Attach the instance pointer to the dev_info data structure */ 364 ddi_set_driver_private(devinfo, ixgbe); 365 366 /* 367 * Initialize for fma support 368 */ 369 ixgbe->fm_capabilities = ixgbe_get_prop(ixgbe, PROP_FM_CAPABLE, 370 0, 0x0f, DDI_FM_EREPORT_CAPABLE | DDI_FM_ACCCHK_CAPABLE | 371 DDI_FM_DMACHK_CAPABLE | DDI_FM_ERRCB_CAPABLE); 372 ixgbe_fm_init(ixgbe); 373 ixgbe->attach_progress |= ATTACH_PROGRESS_FM_INIT; 374 375 /* 376 * Map PCI config space registers 377 */ 378 if (pci_config_setup(devinfo, &osdep->cfg_handle) != DDI_SUCCESS) { 379 ixgbe_error(ixgbe, "Failed to map PCI configurations"); 380 goto attach_fail; 381 } 382 ixgbe->attach_progress |= ATTACH_PROGRESS_PCI_CONFIG; 383 384 /* 385 * Identify the chipset family 386 */ 387 if (ixgbe_identify_hardware(ixgbe) != IXGBE_SUCCESS) { 388 ixgbe_error(ixgbe, "Failed to identify hardware"); 389 goto attach_fail; 390 } 391 392 /* 393 * Map device registers 394 */ 395 if (ixgbe_regs_map(ixgbe) != IXGBE_SUCCESS) { 396 ixgbe_error(ixgbe, "Failed to map device registers"); 397 goto attach_fail; 398 } 399 ixgbe->attach_progress |= ATTACH_PROGRESS_REGS_MAP; 400 401 /* 402 * Initialize driver parameters 403 */ 404 ixgbe_init_properties(ixgbe); 405 ixgbe->attach_progress |= ATTACH_PROGRESS_PROPS; 406 407 /* 408 * Allocate interrupts 409 */ 410 if (ixgbe_alloc_intrs(ixgbe) != IXGBE_SUCCESS) { 411 ixgbe_error(ixgbe, "Failed to allocate interrupts"); 412 goto attach_fail; 413 } 414 ixgbe->attach_progress |= ATTACH_PROGRESS_ALLOC_INTR; 415 416 /* 417 * Allocate rx/tx rings based on the ring numbers. 418 * The actual numbers of rx/tx rings are decided by the number of 419 * allocated interrupt vectors, so we should allocate the rings after 420 * interrupts are allocated. 421 */ 422 if (ixgbe_alloc_rings(ixgbe) != IXGBE_SUCCESS) { 423 ixgbe_error(ixgbe, "Failed to allocate rx and tx rings"); 424 goto attach_fail; 425 } 426 ixgbe->attach_progress |= ATTACH_PROGRESS_ALLOC_RINGS; 427 428 /* 429 * Map rings to interrupt vectors 430 */ 431 if (ixgbe_map_intrs_to_vectors(ixgbe) != IXGBE_SUCCESS) { 432 ixgbe_error(ixgbe, "Failed to map interrupts to vectors"); 433 goto attach_fail; 434 } 435 436 /* 437 * Add interrupt handlers 438 */ 439 if (ixgbe_add_intr_handlers(ixgbe) != IXGBE_SUCCESS) { 440 ixgbe_error(ixgbe, "Failed to add interrupt handlers"); 441 goto attach_fail; 442 } 443 ixgbe->attach_progress |= ATTACH_PROGRESS_ADD_INTR; 444 445 /* 446 * Create a taskq for sfp-change 447 */ 448 (void) sprintf(taskqname, "ixgbe%d_taskq", instance); 449 if ((ixgbe->sfp_taskq = ddi_taskq_create(devinfo, taskqname, 450 1, TASKQ_DEFAULTPRI, 0)) == NULL) { 451 ixgbe_error(ixgbe, "taskq_create failed"); 452 goto attach_fail; 453 } 454 ixgbe->attach_progress |= ATTACH_PROGRESS_SFP_TASKQ; 455 456 /* 457 * Initialize driver parameters 458 */ 459 if (ixgbe_init_driver_settings(ixgbe) != IXGBE_SUCCESS) { 460 ixgbe_error(ixgbe, "Failed to initialize driver settings"); 461 goto attach_fail; 462 } 463 464 /* 465 * Initialize mutexes for this device. 466 * Do this before enabling the interrupt handler and 467 * register the softint to avoid the condition where 468 * interrupt handler can try using uninitialized mutex. 469 */ 470 ixgbe_init_locks(ixgbe); 471 ixgbe->attach_progress |= ATTACH_PROGRESS_LOCKS; 472 473 /* 474 * Initialize chipset hardware 475 */ 476 if (ixgbe_init(ixgbe) != IXGBE_SUCCESS) { 477 ixgbe_error(ixgbe, "Failed to initialize adapter"); 478 goto attach_fail; 479 } 480 ixgbe->link_check_complete = B_FALSE; 481 ixgbe->link_check_hrtime = gethrtime() + 482 (IXGBE_LINK_UP_TIME * 100000000ULL); 483 ixgbe->attach_progress |= ATTACH_PROGRESS_INIT; 484 485 if (ixgbe_check_acc_handle(ixgbe->osdep.cfg_handle) != DDI_FM_OK) { 486 ddi_fm_service_impact(ixgbe->dip, DDI_SERVICE_LOST); 487 goto attach_fail; 488 } 489 490 /* 491 * Initialize statistics 492 */ 493 if (ixgbe_init_stats(ixgbe) != IXGBE_SUCCESS) { 494 ixgbe_error(ixgbe, "Failed to initialize statistics"); 495 goto attach_fail; 496 } 497 ixgbe->attach_progress |= ATTACH_PROGRESS_STATS; 498 499 /* 500 * Register the driver to the MAC 501 */ 502 if (ixgbe_register_mac(ixgbe) != IXGBE_SUCCESS) { 503 ixgbe_error(ixgbe, "Failed to register MAC"); 504 goto attach_fail; 505 } 506 mac_link_update(ixgbe->mac_hdl, LINK_STATE_UNKNOWN); 507 ixgbe->attach_progress |= ATTACH_PROGRESS_MAC; 508 509 ixgbe->periodic_id = ddi_periodic_add(ixgbe_link_timer, ixgbe, 510 IXGBE_CYCLIC_PERIOD, DDI_IPL_0); 511 if (ixgbe->periodic_id == 0) { 512 ixgbe_error(ixgbe, "Failed to add the link check timer"); 513 goto attach_fail; 514 } 515 ixgbe->attach_progress |= ATTACH_PROGRESS_LINK_TIMER; 516 517 /* 518 * Now that mutex locks are initialized, and the chip is also 519 * initialized, enable interrupts. 520 */ 521 if (ixgbe_enable_intrs(ixgbe) != IXGBE_SUCCESS) { 522 ixgbe_error(ixgbe, "Failed to enable DDI interrupts"); 523 goto attach_fail; 524 } 525 ixgbe->attach_progress |= ATTACH_PROGRESS_ENABLE_INTR; 526 527 ixgbe_log(ixgbe, "%s", ixgbe_version); 528 atomic_or_32(&ixgbe->ixgbe_state, IXGBE_INITIALIZED); 529 530 return (DDI_SUCCESS); 531 532 attach_fail: 533 ixgbe_unconfigure(devinfo, ixgbe); 534 return (DDI_FAILURE); 535 } 536 537 /* 538 * ixgbe_detach - Driver detach. 539 * 540 * The detach() function is the complement of the attach routine. 541 * If cmd is set to DDI_DETACH, detach() is used to remove the 542 * state associated with a given instance of a device node 543 * prior to the removal of that instance from the system. 544 * 545 * The detach() function will be called once for each instance 546 * of the device for which there has been a successful attach() 547 * once there are no longer any opens on the device. 548 * 549 * Interrupts routine are disabled, All memory allocated by this 550 * driver are freed. 551 */ 552 static int 553 ixgbe_detach(dev_info_t *devinfo, ddi_detach_cmd_t cmd) 554 { 555 ixgbe_t *ixgbe; 556 557 /* 558 * Check detach command 559 */ 560 switch (cmd) { 561 default: 562 return (DDI_FAILURE); 563 564 case DDI_SUSPEND: 565 return (ixgbe_suspend(devinfo)); 566 567 case DDI_DETACH: 568 break; 569 } 570 571 /* 572 * Get the pointer to the driver private data structure 573 */ 574 ixgbe = (ixgbe_t *)ddi_get_driver_private(devinfo); 575 if (ixgbe == NULL) 576 return (DDI_FAILURE); 577 578 /* 579 * If the device is still running, it needs to be stopped first. 580 * This check is necessary because under some specific circumstances, 581 * the detach routine can be called without stopping the interface 582 * first. 583 */ 584 if (ixgbe->ixgbe_state & IXGBE_STARTED) { 585 atomic_and_32(&ixgbe->ixgbe_state, ~IXGBE_STARTED); 586 mutex_enter(&ixgbe->gen_lock); 587 ixgbe_stop(ixgbe, B_TRUE); 588 mutex_exit(&ixgbe->gen_lock); 589 /* Disable and stop the watchdog timer */ 590 ixgbe_disable_watchdog_timer(ixgbe); 591 } 592 593 /* 594 * Check if there are still rx buffers held by the upper layer. 595 * If so, fail the detach. 596 */ 597 if (!ixgbe_rx_drain(ixgbe)) 598 return (DDI_FAILURE); 599 600 /* 601 * Do the remaining unconfigure routines 602 */ 603 ixgbe_unconfigure(devinfo, ixgbe); 604 605 return (DDI_SUCCESS); 606 } 607 608 static void 609 ixgbe_unconfigure(dev_info_t *devinfo, ixgbe_t *ixgbe) 610 { 611 /* 612 * Disable interrupt 613 */ 614 if (ixgbe->attach_progress & ATTACH_PROGRESS_ENABLE_INTR) { 615 (void) ixgbe_disable_intrs(ixgbe); 616 } 617 618 /* 619 * remove the link check timer 620 */ 621 if (ixgbe->attach_progress & ATTACH_PROGRESS_LINK_TIMER) { 622 if (ixgbe->periodic_id != NULL) { 623 ddi_periodic_delete(ixgbe->periodic_id); 624 ixgbe->periodic_id = NULL; 625 } 626 } 627 628 /* 629 * Unregister MAC 630 */ 631 if (ixgbe->attach_progress & ATTACH_PROGRESS_MAC) { 632 (void) mac_unregister(ixgbe->mac_hdl); 633 } 634 635 /* 636 * Free statistics 637 */ 638 if (ixgbe->attach_progress & ATTACH_PROGRESS_STATS) { 639 kstat_delete((kstat_t *)ixgbe->ixgbe_ks); 640 } 641 642 /* 643 * Remove interrupt handlers 644 */ 645 if (ixgbe->attach_progress & ATTACH_PROGRESS_ADD_INTR) { 646 ixgbe_rem_intr_handlers(ixgbe); 647 } 648 649 /* 650 * Remove taskq for sfp-status-change 651 */ 652 if (ixgbe->attach_progress & ATTACH_PROGRESS_SFP_TASKQ) { 653 ddi_taskq_destroy(ixgbe->sfp_taskq); 654 } 655 656 /* 657 * Remove interrupts 658 */ 659 if (ixgbe->attach_progress & ATTACH_PROGRESS_ALLOC_INTR) { 660 ixgbe_rem_intrs(ixgbe); 661 } 662 663 /* 664 * Remove driver properties 665 */ 666 if (ixgbe->attach_progress & ATTACH_PROGRESS_PROPS) { 667 (void) ddi_prop_remove_all(devinfo); 668 } 669 670 /* 671 * Stop the chipset 672 */ 673 if (ixgbe->attach_progress & ATTACH_PROGRESS_INIT) { 674 mutex_enter(&ixgbe->gen_lock); 675 ixgbe_chip_stop(ixgbe); 676 mutex_exit(&ixgbe->gen_lock); 677 } 678 679 /* 680 * Free register handle 681 */ 682 if (ixgbe->attach_progress & ATTACH_PROGRESS_REGS_MAP) { 683 if (ixgbe->osdep.reg_handle != NULL) 684 ddi_regs_map_free(&ixgbe->osdep.reg_handle); 685 } 686 687 /* 688 * Free PCI config handle 689 */ 690 if (ixgbe->attach_progress & ATTACH_PROGRESS_PCI_CONFIG) { 691 if (ixgbe->osdep.cfg_handle != NULL) 692 pci_config_teardown(&ixgbe->osdep.cfg_handle); 693 } 694 695 /* 696 * Free locks 697 */ 698 if (ixgbe->attach_progress & ATTACH_PROGRESS_LOCKS) { 699 ixgbe_destroy_locks(ixgbe); 700 } 701 702 /* 703 * Free the rx/tx rings 704 */ 705 if (ixgbe->attach_progress & ATTACH_PROGRESS_ALLOC_RINGS) { 706 ixgbe_free_rings(ixgbe); 707 } 708 709 /* 710 * Unregister FMA capabilities 711 */ 712 if (ixgbe->attach_progress & ATTACH_PROGRESS_FM_INIT) { 713 ixgbe_fm_fini(ixgbe); 714 } 715 716 /* 717 * Free the driver data structure 718 */ 719 kmem_free(ixgbe, sizeof (ixgbe_t)); 720 721 ddi_set_driver_private(devinfo, NULL); 722 } 723 724 /* 725 * ixgbe_register_mac - Register the driver and its function pointers with 726 * the GLD interface. 727 */ 728 static int 729 ixgbe_register_mac(ixgbe_t *ixgbe) 730 { 731 struct ixgbe_hw *hw = &ixgbe->hw; 732 mac_register_t *mac; 733 int status; 734 735 if ((mac = mac_alloc(MAC_VERSION)) == NULL) 736 return (IXGBE_FAILURE); 737 738 mac->m_type_ident = MAC_PLUGIN_IDENT_ETHER; 739 mac->m_driver = ixgbe; 740 mac->m_dip = ixgbe->dip; 741 mac->m_src_addr = hw->mac.addr; 742 mac->m_callbacks = &ixgbe_m_callbacks; 743 mac->m_min_sdu = 0; 744 mac->m_max_sdu = ixgbe->default_mtu; 745 mac->m_margin = VLAN_TAGSZ; 746 mac->m_priv_props = ixgbe_priv_props; 747 mac->m_priv_prop_count = IXGBE_MAX_PRIV_PROPS; 748 mac->m_v12n = MAC_VIRT_LEVEL1; 749 750 status = mac_register(mac, &ixgbe->mac_hdl); 751 752 mac_free(mac); 753 754 return ((status == 0) ? IXGBE_SUCCESS : IXGBE_FAILURE); 755 } 756 757 /* 758 * ixgbe_identify_hardware - Identify the type of the chipset. 759 */ 760 static int 761 ixgbe_identify_hardware(ixgbe_t *ixgbe) 762 { 763 struct ixgbe_hw *hw = &ixgbe->hw; 764 struct ixgbe_osdep *osdep = &ixgbe->osdep; 765 766 /* 767 * Get the device id 768 */ 769 hw->vendor_id = 770 pci_config_get16(osdep->cfg_handle, PCI_CONF_VENID); 771 hw->device_id = 772 pci_config_get16(osdep->cfg_handle, PCI_CONF_DEVID); 773 hw->revision_id = 774 pci_config_get8(osdep->cfg_handle, PCI_CONF_REVID); 775 hw->subsystem_device_id = 776 pci_config_get16(osdep->cfg_handle, PCI_CONF_SUBSYSID); 777 hw->subsystem_vendor_id = 778 pci_config_get16(osdep->cfg_handle, PCI_CONF_SUBVENID); 779 780 /* 781 * Set the mac type of the adapter based on the device id 782 */ 783 if (ixgbe_set_mac_type(hw) != IXGBE_SUCCESS) { 784 return (IXGBE_FAILURE); 785 } 786 787 /* 788 * Install adapter capabilities 789 */ 790 switch (hw->mac.type) { 791 case ixgbe_mac_82598EB: 792 ixgbe_log(ixgbe, "identify 82598 adapter\n"); 793 ixgbe->capab = &ixgbe_82598eb_cap; 794 795 if (ixgbe_get_media_type(hw) == ixgbe_media_type_copper) { 796 ixgbe->capab->flags |= IXGBE_FLAG_FAN_FAIL_CAPABLE; 797 ixgbe->capab->other_intr |= IXGBE_EICR_GPI_SDP1; 798 } 799 ixgbe->capab->other_intr |= IXGBE_EICR_LSC; 800 801 break; 802 case ixgbe_mac_82599EB: 803 ixgbe_log(ixgbe, "identify 82599 adapter\n"); 804 ixgbe->capab = &ixgbe_82599eb_cap; 805 806 ixgbe->capab->other_intr = (IXGBE_EICR_GPI_SDP1 | 807 IXGBE_EICR_GPI_SDP2 | IXGBE_EICR_LSC); 808 809 break; 810 default: 811 ixgbe_log(ixgbe, 812 "adapter not supported in ixgbe_identify_hardware(): %d\n", 813 hw->mac.type); 814 return (IXGBE_FAILURE); 815 } 816 817 return (IXGBE_SUCCESS); 818 } 819 820 /* 821 * ixgbe_regs_map - Map the device registers. 822 * 823 */ 824 static int 825 ixgbe_regs_map(ixgbe_t *ixgbe) 826 { 827 dev_info_t *devinfo = ixgbe->dip; 828 struct ixgbe_hw *hw = &ixgbe->hw; 829 struct ixgbe_osdep *osdep = &ixgbe->osdep; 830 off_t mem_size; 831 832 /* 833 * First get the size of device registers to be mapped. 834 */ 835 if (ddi_dev_regsize(devinfo, IXGBE_ADAPTER_REGSET, &mem_size) 836 != DDI_SUCCESS) { 837 return (IXGBE_FAILURE); 838 } 839 840 /* 841 * Call ddi_regs_map_setup() to map registers 842 */ 843 if ((ddi_regs_map_setup(devinfo, IXGBE_ADAPTER_REGSET, 844 (caddr_t *)&hw->hw_addr, 0, 845 mem_size, &ixgbe_regs_acc_attr, 846 &osdep->reg_handle)) != DDI_SUCCESS) { 847 return (IXGBE_FAILURE); 848 } 849 850 return (IXGBE_SUCCESS); 851 } 852 853 /* 854 * ixgbe_init_properties - Initialize driver properties. 855 */ 856 static void 857 ixgbe_init_properties(ixgbe_t *ixgbe) 858 { 859 /* 860 * Get conf file properties, including link settings 861 * jumbo frames, ring number, descriptor number, etc. 862 */ 863 ixgbe_get_conf(ixgbe); 864 865 ixgbe_init_params(ixgbe); 866 } 867 868 /* 869 * ixgbe_init_driver_settings - Initialize driver settings. 870 * 871 * The settings include hardware function pointers, bus information, 872 * rx/tx rings settings, link state, and any other parameters that 873 * need to be setup during driver initialization. 874 */ 875 static int 876 ixgbe_init_driver_settings(ixgbe_t *ixgbe) 877 { 878 struct ixgbe_hw *hw = &ixgbe->hw; 879 dev_info_t *devinfo = ixgbe->dip; 880 ixgbe_rx_ring_t *rx_ring; 881 ixgbe_tx_ring_t *tx_ring; 882 uint32_t rx_size; 883 uint32_t tx_size; 884 int i; 885 886 /* 887 * Initialize chipset specific hardware function pointers 888 */ 889 if (ixgbe_init_shared_code(hw) != IXGBE_SUCCESS) { 890 return (IXGBE_FAILURE); 891 } 892 893 /* 894 * Get the system page size 895 */ 896 ixgbe->sys_page_size = ddi_ptob(devinfo, (ulong_t)1); 897 898 /* 899 * Set rx buffer size 900 * 901 * The IP header alignment room is counted in the calculation. 902 * The rx buffer size is in unit of 1K that is required by the 903 * chipset hardware. 904 */ 905 rx_size = ixgbe->max_frame_size + IPHDR_ALIGN_ROOM; 906 ixgbe->rx_buf_size = ((rx_size >> 10) + 907 ((rx_size & (((uint32_t)1 << 10) - 1)) > 0 ? 1 : 0)) << 10; 908 909 /* 910 * Set tx buffer size 911 */ 912 tx_size = ixgbe->max_frame_size; 913 ixgbe->tx_buf_size = ((tx_size >> 10) + 914 ((tx_size & (((uint32_t)1 << 10) - 1)) > 0 ? 1 : 0)) << 10; 915 916 /* 917 * Initialize rx/tx rings parameters 918 */ 919 for (i = 0; i < ixgbe->num_rx_rings; i++) { 920 rx_ring = &ixgbe->rx_rings[i]; 921 rx_ring->index = i; 922 rx_ring->ixgbe = ixgbe; 923 } 924 925 for (i = 0; i < ixgbe->num_tx_rings; i++) { 926 tx_ring = &ixgbe->tx_rings[i]; 927 tx_ring->index = i; 928 tx_ring->ixgbe = ixgbe; 929 if (ixgbe->tx_head_wb_enable) 930 tx_ring->tx_recycle = ixgbe_tx_recycle_head_wb; 931 else 932 tx_ring->tx_recycle = ixgbe_tx_recycle_legacy; 933 934 tx_ring->ring_size = ixgbe->tx_ring_size; 935 tx_ring->free_list_size = ixgbe->tx_ring_size + 936 (ixgbe->tx_ring_size >> 1); 937 } 938 939 /* 940 * Initialize values of interrupt throttling rate 941 */ 942 for (i = 1; i < MAX_INTR_VECTOR; i++) 943 ixgbe->intr_throttling[i] = ixgbe->intr_throttling[0]; 944 945 /* 946 * The initial link state should be "unknown" 947 */ 948 ixgbe->link_state = LINK_STATE_UNKNOWN; 949 950 return (IXGBE_SUCCESS); 951 } 952 953 /* 954 * ixgbe_init_locks - Initialize locks. 955 */ 956 static void 957 ixgbe_init_locks(ixgbe_t *ixgbe) 958 { 959 ixgbe_rx_ring_t *rx_ring; 960 ixgbe_tx_ring_t *tx_ring; 961 int i; 962 963 for (i = 0; i < ixgbe->num_rx_rings; i++) { 964 rx_ring = &ixgbe->rx_rings[i]; 965 mutex_init(&rx_ring->rx_lock, NULL, 966 MUTEX_DRIVER, DDI_INTR_PRI(ixgbe->intr_pri)); 967 } 968 969 for (i = 0; i < ixgbe->num_tx_rings; i++) { 970 tx_ring = &ixgbe->tx_rings[i]; 971 mutex_init(&tx_ring->tx_lock, NULL, 972 MUTEX_DRIVER, DDI_INTR_PRI(ixgbe->intr_pri)); 973 mutex_init(&tx_ring->recycle_lock, NULL, 974 MUTEX_DRIVER, DDI_INTR_PRI(ixgbe->intr_pri)); 975 mutex_init(&tx_ring->tcb_head_lock, NULL, 976 MUTEX_DRIVER, DDI_INTR_PRI(ixgbe->intr_pri)); 977 mutex_init(&tx_ring->tcb_tail_lock, NULL, 978 MUTEX_DRIVER, DDI_INTR_PRI(ixgbe->intr_pri)); 979 } 980 981 mutex_init(&ixgbe->gen_lock, NULL, 982 MUTEX_DRIVER, DDI_INTR_PRI(ixgbe->intr_pri)); 983 984 mutex_init(&ixgbe->watchdog_lock, NULL, 985 MUTEX_DRIVER, DDI_INTR_PRI(ixgbe->intr_pri)); 986 } 987 988 /* 989 * ixgbe_destroy_locks - Destroy locks. 990 */ 991 static void 992 ixgbe_destroy_locks(ixgbe_t *ixgbe) 993 { 994 ixgbe_rx_ring_t *rx_ring; 995 ixgbe_tx_ring_t *tx_ring; 996 int i; 997 998 for (i = 0; i < ixgbe->num_rx_rings; i++) { 999 rx_ring = &ixgbe->rx_rings[i]; 1000 mutex_destroy(&rx_ring->rx_lock); 1001 } 1002 1003 for (i = 0; i < ixgbe->num_tx_rings; i++) { 1004 tx_ring = &ixgbe->tx_rings[i]; 1005 mutex_destroy(&tx_ring->tx_lock); 1006 mutex_destroy(&tx_ring->recycle_lock); 1007 mutex_destroy(&tx_ring->tcb_head_lock); 1008 mutex_destroy(&tx_ring->tcb_tail_lock); 1009 } 1010 1011 mutex_destroy(&ixgbe->gen_lock); 1012 mutex_destroy(&ixgbe->watchdog_lock); 1013 } 1014 1015 static int 1016 ixgbe_resume(dev_info_t *devinfo) 1017 { 1018 ixgbe_t *ixgbe; 1019 int i; 1020 1021 ixgbe = (ixgbe_t *)ddi_get_driver_private(devinfo); 1022 if (ixgbe == NULL) 1023 return (DDI_FAILURE); 1024 1025 mutex_enter(&ixgbe->gen_lock); 1026 1027 if (ixgbe->ixgbe_state & IXGBE_STARTED) { 1028 if (ixgbe_start(ixgbe, B_FALSE) != IXGBE_SUCCESS) { 1029 mutex_exit(&ixgbe->gen_lock); 1030 return (DDI_FAILURE); 1031 } 1032 1033 /* 1034 * Enable and start the watchdog timer 1035 */ 1036 ixgbe_enable_watchdog_timer(ixgbe); 1037 } 1038 1039 atomic_and_32(&ixgbe->ixgbe_state, ~IXGBE_SUSPENDED); 1040 1041 if (ixgbe->ixgbe_state & IXGBE_STARTED) { 1042 for (i = 0; i < ixgbe->num_tx_rings; i++) { 1043 mac_tx_ring_update(ixgbe->mac_hdl, 1044 ixgbe->tx_rings[i].ring_handle); 1045 } 1046 } 1047 1048 mutex_exit(&ixgbe->gen_lock); 1049 1050 return (DDI_SUCCESS); 1051 } 1052 1053 static int 1054 ixgbe_suspend(dev_info_t *devinfo) 1055 { 1056 ixgbe_t *ixgbe; 1057 1058 ixgbe = (ixgbe_t *)ddi_get_driver_private(devinfo); 1059 if (ixgbe == NULL) 1060 return (DDI_FAILURE); 1061 1062 mutex_enter(&ixgbe->gen_lock); 1063 1064 atomic_or_32(&ixgbe->ixgbe_state, IXGBE_SUSPENDED); 1065 if (!(ixgbe->ixgbe_state & IXGBE_STARTED)) { 1066 mutex_exit(&ixgbe->gen_lock); 1067 return (DDI_SUCCESS); 1068 } 1069 ixgbe_stop(ixgbe, B_FALSE); 1070 1071 mutex_exit(&ixgbe->gen_lock); 1072 1073 /* 1074 * Disable and stop the watchdog timer 1075 */ 1076 ixgbe_disable_watchdog_timer(ixgbe); 1077 1078 return (DDI_SUCCESS); 1079 } 1080 1081 /* 1082 * ixgbe_init - Initialize the device. 1083 */ 1084 static int 1085 ixgbe_init(ixgbe_t *ixgbe) 1086 { 1087 struct ixgbe_hw *hw = &ixgbe->hw; 1088 1089 mutex_enter(&ixgbe->gen_lock); 1090 1091 /* 1092 * Reset chipset to put the hardware in a known state 1093 * before we try to do anything with the eeprom. 1094 */ 1095 if (ixgbe_reset_hw(hw) != IXGBE_SUCCESS) { 1096 ixgbe_fm_ereport(ixgbe, DDI_FM_DEVICE_INVAL_STATE); 1097 goto init_fail; 1098 } 1099 1100 /* 1101 * Need to init eeprom before validating the checksum. 1102 */ 1103 if (ixgbe_init_eeprom_params(hw) < 0) { 1104 ixgbe_error(ixgbe, 1105 "Unable to intitialize the eeprom interface."); 1106 ixgbe_fm_ereport(ixgbe, DDI_FM_DEVICE_INVAL_STATE); 1107 goto init_fail; 1108 } 1109 1110 /* 1111 * NVM validation 1112 */ 1113 if (ixgbe_validate_eeprom_checksum(hw, NULL) < 0) { 1114 /* 1115 * Some PCI-E parts fail the first check due to 1116 * the link being in sleep state. Call it again, 1117 * if it fails a second time it's a real issue. 1118 */ 1119 if (ixgbe_validate_eeprom_checksum(hw, NULL) < 0) { 1120 ixgbe_error(ixgbe, 1121 "Invalid NVM checksum. Please contact " 1122 "the vendor to update the NVM."); 1123 ixgbe_fm_ereport(ixgbe, DDI_FM_DEVICE_INVAL_STATE); 1124 goto init_fail; 1125 } 1126 } 1127 1128 /* 1129 * Setup default flow control thresholds - enable/disable 1130 * & flow control type is controlled by ixgbe.conf 1131 */ 1132 hw->fc.high_water = DEFAULT_FCRTH; 1133 hw->fc.low_water = DEFAULT_FCRTL; 1134 hw->fc.pause_time = DEFAULT_FCPAUSE; 1135 hw->fc.send_xon = B_TRUE; 1136 1137 /* 1138 * Initialize link settings 1139 */ 1140 (void) ixgbe_driver_setup_link(ixgbe, B_FALSE); 1141 1142 /* 1143 * Initialize the chipset hardware 1144 */ 1145 if (ixgbe_chip_start(ixgbe) != IXGBE_SUCCESS) { 1146 ixgbe_fm_ereport(ixgbe, DDI_FM_DEVICE_INVAL_STATE); 1147 goto init_fail; 1148 } 1149 1150 if (ixgbe_check_acc_handle(ixgbe->osdep.reg_handle) != DDI_FM_OK) { 1151 goto init_fail; 1152 } 1153 1154 mutex_exit(&ixgbe->gen_lock); 1155 return (IXGBE_SUCCESS); 1156 1157 init_fail: 1158 /* 1159 * Reset PHY 1160 */ 1161 (void) ixgbe_reset_phy(hw); 1162 1163 mutex_exit(&ixgbe->gen_lock); 1164 ddi_fm_service_impact(ixgbe->dip, DDI_SERVICE_LOST); 1165 return (IXGBE_FAILURE); 1166 } 1167 1168 /* 1169 * ixgbe_chip_start - Initialize and start the chipset hardware. 1170 */ 1171 static int 1172 ixgbe_chip_start(ixgbe_t *ixgbe) 1173 { 1174 struct ixgbe_hw *hw = &ixgbe->hw; 1175 int ret_val, i; 1176 1177 ASSERT(mutex_owned(&ixgbe->gen_lock)); 1178 1179 /* 1180 * Get the mac address 1181 * This function should handle SPARC case correctly. 1182 */ 1183 if (!ixgbe_find_mac_address(ixgbe)) { 1184 ixgbe_error(ixgbe, "Failed to get the mac address"); 1185 return (IXGBE_FAILURE); 1186 } 1187 1188 /* 1189 * Validate the mac address 1190 */ 1191 (void) ixgbe_init_rx_addrs(hw); 1192 if (!is_valid_mac_addr(hw->mac.addr)) { 1193 ixgbe_error(ixgbe, "Invalid mac address"); 1194 return (IXGBE_FAILURE); 1195 } 1196 1197 /* 1198 * Configure/Initialize hardware 1199 */ 1200 ret_val = ixgbe_init_hw(hw); 1201 if (ret_val != IXGBE_SUCCESS) { 1202 if (ret_val == IXGBE_ERR_EEPROM_VERSION) { 1203 ixgbe_error(ixgbe, 1204 "This 82599 device is pre-release and contains" 1205 " outdated firmware, please contact your hardware" 1206 " vendor for a replacement."); 1207 } else { 1208 ixgbe_error(ixgbe, "Failed to initialize hardware"); 1209 return (IXGBE_FAILURE); 1210 } 1211 } 1212 1213 /* 1214 * Setup adapter interrupt vectors 1215 */ 1216 ixgbe_setup_adapter_vector(ixgbe); 1217 1218 /* 1219 * Initialize unicast addresses. 1220 */ 1221 ixgbe_init_unicst(ixgbe); 1222 1223 /* 1224 * Setup and initialize the mctable structures. 1225 */ 1226 ixgbe_setup_multicst(ixgbe); 1227 1228 /* 1229 * Set interrupt throttling rate 1230 */ 1231 for (i = 0; i < ixgbe->intr_cnt; i++) { 1232 IXGBE_WRITE_REG(hw, IXGBE_EITR(i), ixgbe->intr_throttling[i]); 1233 } 1234 1235 /* 1236 * Save the state of the phy 1237 */ 1238 ixgbe_get_hw_state(ixgbe); 1239 1240 /* 1241 * Make sure driver has control 1242 */ 1243 ixgbe_get_driver_control(hw); 1244 1245 return (IXGBE_SUCCESS); 1246 } 1247 1248 /* 1249 * ixgbe_chip_stop - Stop the chipset hardware 1250 */ 1251 static void 1252 ixgbe_chip_stop(ixgbe_t *ixgbe) 1253 { 1254 struct ixgbe_hw *hw = &ixgbe->hw; 1255 1256 ASSERT(mutex_owned(&ixgbe->gen_lock)); 1257 1258 /* 1259 * Tell firmware driver is no longer in control 1260 */ 1261 ixgbe_release_driver_control(hw); 1262 1263 /* 1264 * Reset the chipset 1265 */ 1266 (void) ixgbe_reset_hw(hw); 1267 1268 /* 1269 * Reset PHY 1270 */ 1271 (void) ixgbe_reset_phy(hw); 1272 } 1273 1274 /* 1275 * ixgbe_reset - Reset the chipset and re-start the driver. 1276 * 1277 * It involves stopping and re-starting the chipset, 1278 * and re-configuring the rx/tx rings. 1279 */ 1280 static int 1281 ixgbe_reset(ixgbe_t *ixgbe) 1282 { 1283 int i; 1284 1285 /* 1286 * Disable and stop the watchdog timer 1287 */ 1288 ixgbe_disable_watchdog_timer(ixgbe); 1289 1290 mutex_enter(&ixgbe->gen_lock); 1291 1292 ASSERT(ixgbe->ixgbe_state & IXGBE_STARTED); 1293 atomic_and_32(&ixgbe->ixgbe_state, ~IXGBE_STARTED); 1294 1295 ixgbe_stop(ixgbe, B_FALSE); 1296 1297 if (ixgbe_start(ixgbe, B_FALSE) != IXGBE_SUCCESS) { 1298 mutex_exit(&ixgbe->gen_lock); 1299 return (IXGBE_FAILURE); 1300 } 1301 1302 /* 1303 * After resetting, need to recheck the link status. 1304 */ 1305 ixgbe->link_check_complete = B_FALSE; 1306 ixgbe->link_check_hrtime = gethrtime() + 1307 (IXGBE_LINK_UP_TIME * 100000000ULL); 1308 1309 atomic_or_32(&ixgbe->ixgbe_state, IXGBE_STARTED); 1310 1311 if (!(ixgbe->ixgbe_state & IXGBE_SUSPENDED)) { 1312 for (i = 0; i < ixgbe->num_tx_rings; i++) { 1313 mac_tx_ring_update(ixgbe->mac_hdl, 1314 ixgbe->tx_rings[i].ring_handle); 1315 } 1316 } 1317 1318 mutex_exit(&ixgbe->gen_lock); 1319 1320 /* 1321 * Enable and start the watchdog timer 1322 */ 1323 ixgbe_enable_watchdog_timer(ixgbe); 1324 1325 return (IXGBE_SUCCESS); 1326 } 1327 1328 /* 1329 * ixgbe_tx_clean - Clean the pending transmit packets and DMA resources. 1330 */ 1331 static void 1332 ixgbe_tx_clean(ixgbe_t *ixgbe) 1333 { 1334 ixgbe_tx_ring_t *tx_ring; 1335 tx_control_block_t *tcb; 1336 link_list_t pending_list; 1337 uint32_t desc_num; 1338 int i, j; 1339 1340 LINK_LIST_INIT(&pending_list); 1341 1342 for (i = 0; i < ixgbe->num_tx_rings; i++) { 1343 tx_ring = &ixgbe->tx_rings[i]; 1344 1345 mutex_enter(&tx_ring->recycle_lock); 1346 1347 /* 1348 * Clean the pending tx data - the pending packets in the 1349 * work_list that have no chances to be transmitted again. 1350 * 1351 * We must ensure the chipset is stopped or the link is down 1352 * before cleaning the transmit packets. 1353 */ 1354 desc_num = 0; 1355 for (j = 0; j < tx_ring->ring_size; j++) { 1356 tcb = tx_ring->work_list[j]; 1357 if (tcb != NULL) { 1358 desc_num += tcb->desc_num; 1359 1360 tx_ring->work_list[j] = NULL; 1361 1362 ixgbe_free_tcb(tcb); 1363 1364 LIST_PUSH_TAIL(&pending_list, &tcb->link); 1365 } 1366 } 1367 1368 if (desc_num > 0) { 1369 atomic_add_32(&tx_ring->tbd_free, desc_num); 1370 ASSERT(tx_ring->tbd_free == tx_ring->ring_size); 1371 1372 /* 1373 * Reset the head and tail pointers of the tbd ring; 1374 * Reset the writeback head if it's enable. 1375 */ 1376 tx_ring->tbd_head = 0; 1377 tx_ring->tbd_tail = 0; 1378 if (ixgbe->tx_head_wb_enable) 1379 *tx_ring->tbd_head_wb = 0; 1380 1381 IXGBE_WRITE_REG(&ixgbe->hw, 1382 IXGBE_TDH(tx_ring->index), 0); 1383 IXGBE_WRITE_REG(&ixgbe->hw, 1384 IXGBE_TDT(tx_ring->index), 0); 1385 } 1386 1387 mutex_exit(&tx_ring->recycle_lock); 1388 1389 /* 1390 * Add the tx control blocks in the pending list to 1391 * the free list. 1392 */ 1393 ixgbe_put_free_list(tx_ring, &pending_list); 1394 } 1395 } 1396 1397 /* 1398 * ixgbe_tx_drain - Drain the tx rings to allow pending packets to be 1399 * transmitted. 1400 */ 1401 static boolean_t 1402 ixgbe_tx_drain(ixgbe_t *ixgbe) 1403 { 1404 ixgbe_tx_ring_t *tx_ring; 1405 boolean_t done; 1406 int i, j; 1407 1408 /* 1409 * Wait for a specific time to allow pending tx packets 1410 * to be transmitted. 1411 * 1412 * Check the counter tbd_free to see if transmission is done. 1413 * No lock protection is needed here. 1414 * 1415 * Return B_TRUE if all pending packets have been transmitted; 1416 * Otherwise return B_FALSE; 1417 */ 1418 for (i = 0; i < TX_DRAIN_TIME; i++) { 1419 1420 done = B_TRUE; 1421 for (j = 0; j < ixgbe->num_tx_rings; j++) { 1422 tx_ring = &ixgbe->tx_rings[j]; 1423 done = done && 1424 (tx_ring->tbd_free == tx_ring->ring_size); 1425 } 1426 1427 if (done) 1428 break; 1429 1430 msec_delay(1); 1431 } 1432 1433 return (done); 1434 } 1435 1436 /* 1437 * ixgbe_rx_drain - Wait for all rx buffers to be released by upper layer. 1438 */ 1439 static boolean_t 1440 ixgbe_rx_drain(ixgbe_t *ixgbe) 1441 { 1442 boolean_t done = B_TRUE; 1443 int i; 1444 1445 /* 1446 * Polling the rx free list to check if those rx buffers held by 1447 * the upper layer are released. 1448 * 1449 * Check the counter rcb_free to see if all pending buffers are 1450 * released. No lock protection is needed here. 1451 * 1452 * Return B_TRUE if all pending buffers have been released; 1453 * Otherwise return B_FALSE; 1454 */ 1455 for (i = 0; i < RX_DRAIN_TIME; i++) { 1456 done = (ixgbe->rcb_pending == 0); 1457 1458 if (done) 1459 break; 1460 1461 msec_delay(1); 1462 } 1463 1464 return (done); 1465 } 1466 1467 /* 1468 * ixgbe_start - Start the driver/chipset. 1469 */ 1470 int 1471 ixgbe_start(ixgbe_t *ixgbe, boolean_t alloc_buffer) 1472 { 1473 int i; 1474 1475 ASSERT(mutex_owned(&ixgbe->gen_lock)); 1476 1477 if (alloc_buffer) { 1478 if (ixgbe_alloc_rx_data(ixgbe) != IXGBE_SUCCESS) { 1479 ixgbe_error(ixgbe, 1480 "Failed to allocate software receive rings"); 1481 return (IXGBE_FAILURE); 1482 } 1483 1484 /* Allocate buffers for all the rx/tx rings */ 1485 if (ixgbe_alloc_dma(ixgbe) != IXGBE_SUCCESS) { 1486 ixgbe_error(ixgbe, "Failed to allocate DMA resource"); 1487 return (IXGBE_FAILURE); 1488 } 1489 1490 ixgbe->tx_ring_init = B_TRUE; 1491 } else { 1492 ixgbe->tx_ring_init = B_FALSE; 1493 } 1494 1495 for (i = 0; i < ixgbe->num_rx_rings; i++) 1496 mutex_enter(&ixgbe->rx_rings[i].rx_lock); 1497 for (i = 0; i < ixgbe->num_tx_rings; i++) 1498 mutex_enter(&ixgbe->tx_rings[i].tx_lock); 1499 1500 /* 1501 * Start the chipset hardware 1502 */ 1503 if (ixgbe_chip_start(ixgbe) != IXGBE_SUCCESS) { 1504 ixgbe_fm_ereport(ixgbe, DDI_FM_DEVICE_INVAL_STATE); 1505 goto start_failure; 1506 } 1507 1508 if (ixgbe_check_acc_handle(ixgbe->osdep.reg_handle) != DDI_FM_OK) { 1509 goto start_failure; 1510 } 1511 1512 /* 1513 * Setup the rx/tx rings 1514 */ 1515 ixgbe_setup_rings(ixgbe); 1516 1517 /* 1518 * ixgbe_start() will be called when resetting, however if reset 1519 * happens, we need to clear the ERROR and STALL flags before 1520 * enabling the interrupts. 1521 */ 1522 atomic_and_32(&ixgbe->ixgbe_state, ~(IXGBE_ERROR | IXGBE_STALL)); 1523 1524 /* 1525 * Enable adapter interrupts 1526 * The interrupts must be enabled after the driver state is START 1527 */ 1528 ixgbe_enable_adapter_interrupts(ixgbe); 1529 1530 for (i = ixgbe->num_tx_rings - 1; i >= 0; i--) 1531 mutex_exit(&ixgbe->tx_rings[i].tx_lock); 1532 for (i = ixgbe->num_rx_rings - 1; i >= 0; i--) 1533 mutex_exit(&ixgbe->rx_rings[i].rx_lock); 1534 1535 return (IXGBE_SUCCESS); 1536 1537 start_failure: 1538 for (i = ixgbe->num_tx_rings - 1; i >= 0; i--) 1539 mutex_exit(&ixgbe->tx_rings[i].tx_lock); 1540 for (i = ixgbe->num_rx_rings - 1; i >= 0; i--) 1541 mutex_exit(&ixgbe->rx_rings[i].rx_lock); 1542 1543 ddi_fm_service_impact(ixgbe->dip, DDI_SERVICE_LOST); 1544 1545 return (IXGBE_FAILURE); 1546 } 1547 1548 /* 1549 * ixgbe_stop - Stop the driver/chipset. 1550 */ 1551 void 1552 ixgbe_stop(ixgbe_t *ixgbe, boolean_t free_buffer) 1553 { 1554 int i; 1555 1556 ASSERT(mutex_owned(&ixgbe->gen_lock)); 1557 1558 /* 1559 * Disable the adapter interrupts 1560 */ 1561 ixgbe_disable_adapter_interrupts(ixgbe); 1562 1563 /* 1564 * Drain the pending tx packets 1565 */ 1566 (void) ixgbe_tx_drain(ixgbe); 1567 1568 for (i = 0; i < ixgbe->num_rx_rings; i++) 1569 mutex_enter(&ixgbe->rx_rings[i].rx_lock); 1570 for (i = 0; i < ixgbe->num_tx_rings; i++) 1571 mutex_enter(&ixgbe->tx_rings[i].tx_lock); 1572 1573 /* 1574 * Stop the chipset hardware 1575 */ 1576 ixgbe_chip_stop(ixgbe); 1577 1578 if (ixgbe_check_acc_handle(ixgbe->osdep.reg_handle) != DDI_FM_OK) { 1579 ddi_fm_service_impact(ixgbe->dip, DDI_SERVICE_LOST); 1580 } 1581 1582 /* 1583 * Clean the pending tx data/resources 1584 */ 1585 ixgbe_tx_clean(ixgbe); 1586 1587 for (i = ixgbe->num_tx_rings - 1; i >= 0; i--) 1588 mutex_exit(&ixgbe->tx_rings[i].tx_lock); 1589 for (i = ixgbe->num_rx_rings - 1; i >= 0; i--) 1590 mutex_exit(&ixgbe->rx_rings[i].rx_lock); 1591 1592 if (ixgbe->link_state == LINK_STATE_UP) { 1593 ixgbe->link_state = LINK_STATE_UNKNOWN; 1594 mac_link_update(ixgbe->mac_hdl, ixgbe->link_state); 1595 } 1596 1597 if (free_buffer) { 1598 /* 1599 * Release the DMA/memory resources of rx/tx rings 1600 */ 1601 ixgbe_free_dma(ixgbe); 1602 ixgbe_free_rx_data(ixgbe); 1603 } 1604 } 1605 1606 /* 1607 * ixgbe_alloc_rings - Allocate memory space for rx/tx rings. 1608 */ 1609 static int 1610 ixgbe_alloc_rings(ixgbe_t *ixgbe) 1611 { 1612 /* 1613 * Allocate memory space for rx rings 1614 */ 1615 ixgbe->rx_rings = kmem_zalloc( 1616 sizeof (ixgbe_rx_ring_t) * ixgbe->num_rx_rings, 1617 KM_NOSLEEP); 1618 1619 if (ixgbe->rx_rings == NULL) { 1620 return (IXGBE_FAILURE); 1621 } 1622 1623 /* 1624 * Allocate memory space for tx rings 1625 */ 1626 ixgbe->tx_rings = kmem_zalloc( 1627 sizeof (ixgbe_tx_ring_t) * ixgbe->num_tx_rings, 1628 KM_NOSLEEP); 1629 1630 if (ixgbe->tx_rings == NULL) { 1631 kmem_free(ixgbe->rx_rings, 1632 sizeof (ixgbe_rx_ring_t) * ixgbe->num_rx_rings); 1633 ixgbe->rx_rings = NULL; 1634 return (IXGBE_FAILURE); 1635 } 1636 1637 /* 1638 * Allocate memory space for rx ring groups 1639 */ 1640 ixgbe->rx_groups = kmem_zalloc( 1641 sizeof (ixgbe_rx_group_t) * ixgbe->num_rx_groups, 1642 KM_NOSLEEP); 1643 1644 if (ixgbe->rx_groups == NULL) { 1645 kmem_free(ixgbe->rx_rings, 1646 sizeof (ixgbe_rx_ring_t) * ixgbe->num_rx_rings); 1647 kmem_free(ixgbe->tx_rings, 1648 sizeof (ixgbe_tx_ring_t) * ixgbe->num_tx_rings); 1649 ixgbe->rx_rings = NULL; 1650 ixgbe->tx_rings = NULL; 1651 return (IXGBE_FAILURE); 1652 } 1653 1654 return (IXGBE_SUCCESS); 1655 } 1656 1657 /* 1658 * ixgbe_free_rings - Free the memory space of rx/tx rings. 1659 */ 1660 static void 1661 ixgbe_free_rings(ixgbe_t *ixgbe) 1662 { 1663 if (ixgbe->rx_rings != NULL) { 1664 kmem_free(ixgbe->rx_rings, 1665 sizeof (ixgbe_rx_ring_t) * ixgbe->num_rx_rings); 1666 ixgbe->rx_rings = NULL; 1667 } 1668 1669 if (ixgbe->tx_rings != NULL) { 1670 kmem_free(ixgbe->tx_rings, 1671 sizeof (ixgbe_tx_ring_t) * ixgbe->num_tx_rings); 1672 ixgbe->tx_rings = NULL; 1673 } 1674 1675 if (ixgbe->rx_groups != NULL) { 1676 kmem_free(ixgbe->rx_groups, 1677 sizeof (ixgbe_rx_group_t) * ixgbe->num_rx_groups); 1678 ixgbe->rx_groups = NULL; 1679 } 1680 } 1681 1682 static int 1683 ixgbe_alloc_rx_data(ixgbe_t *ixgbe) 1684 { 1685 ixgbe_rx_ring_t *rx_ring; 1686 int i; 1687 1688 for (i = 0; i < ixgbe->num_rx_rings; i++) { 1689 rx_ring = &ixgbe->rx_rings[i]; 1690 if (ixgbe_alloc_rx_ring_data(rx_ring) != IXGBE_SUCCESS) 1691 goto alloc_rx_rings_failure; 1692 } 1693 return (IXGBE_SUCCESS); 1694 1695 alloc_rx_rings_failure: 1696 ixgbe_free_rx_data(ixgbe); 1697 return (IXGBE_FAILURE); 1698 } 1699 1700 static void 1701 ixgbe_free_rx_data(ixgbe_t *ixgbe) 1702 { 1703 ixgbe_rx_ring_t *rx_ring; 1704 ixgbe_rx_data_t *rx_data; 1705 int i; 1706 1707 for (i = 0; i < ixgbe->num_rx_rings; i++) { 1708 rx_ring = &ixgbe->rx_rings[i]; 1709 1710 mutex_enter(&ixgbe->rx_pending_lock); 1711 rx_data = rx_ring->rx_data; 1712 1713 if (rx_data != NULL) { 1714 rx_data->flag |= IXGBE_RX_STOPPED; 1715 1716 if (rx_data->rcb_pending == 0) { 1717 ixgbe_free_rx_ring_data(rx_data); 1718 rx_ring->rx_data = NULL; 1719 } 1720 } 1721 1722 mutex_exit(&ixgbe->rx_pending_lock); 1723 } 1724 } 1725 1726 /* 1727 * ixgbe_setup_rings - Setup rx/tx rings. 1728 */ 1729 static void 1730 ixgbe_setup_rings(ixgbe_t *ixgbe) 1731 { 1732 /* 1733 * Setup the rx/tx rings, including the following: 1734 * 1735 * 1. Setup the descriptor ring and the control block buffers; 1736 * 2. Initialize necessary registers for receive/transmit; 1737 * 3. Initialize software pointers/parameters for receive/transmit; 1738 */ 1739 ixgbe_setup_rx(ixgbe); 1740 1741 ixgbe_setup_tx(ixgbe); 1742 } 1743 1744 static void 1745 ixgbe_setup_rx_ring(ixgbe_rx_ring_t *rx_ring) 1746 { 1747 ixgbe_t *ixgbe = rx_ring->ixgbe; 1748 ixgbe_rx_data_t *rx_data = rx_ring->rx_data; 1749 struct ixgbe_hw *hw = &ixgbe->hw; 1750 rx_control_block_t *rcb; 1751 union ixgbe_adv_rx_desc *rbd; 1752 uint32_t size; 1753 uint32_t buf_low; 1754 uint32_t buf_high; 1755 uint32_t reg_val; 1756 int i; 1757 1758 ASSERT(mutex_owned(&rx_ring->rx_lock)); 1759 ASSERT(mutex_owned(&ixgbe->gen_lock)); 1760 1761 for (i = 0; i < ixgbe->rx_ring_size; i++) { 1762 rcb = rx_data->work_list[i]; 1763 rbd = &rx_data->rbd_ring[i]; 1764 1765 rbd->read.pkt_addr = rcb->rx_buf.dma_address; 1766 rbd->read.hdr_addr = NULL; 1767 } 1768 1769 /* 1770 * Initialize the length register 1771 */ 1772 size = rx_data->ring_size * sizeof (union ixgbe_adv_rx_desc); 1773 IXGBE_WRITE_REG(hw, IXGBE_RDLEN(rx_ring->index), size); 1774 1775 /* 1776 * Initialize the base address registers 1777 */ 1778 buf_low = (uint32_t)rx_data->rbd_area.dma_address; 1779 buf_high = (uint32_t)(rx_data->rbd_area.dma_address >> 32); 1780 IXGBE_WRITE_REG(hw, IXGBE_RDBAH(rx_ring->index), buf_high); 1781 IXGBE_WRITE_REG(hw, IXGBE_RDBAL(rx_ring->index), buf_low); 1782 1783 /* 1784 * Setup head & tail pointers 1785 */ 1786 IXGBE_WRITE_REG(hw, IXGBE_RDT(rx_ring->index), rx_data->ring_size - 1); 1787 IXGBE_WRITE_REG(hw, IXGBE_RDH(rx_ring->index), 0); 1788 1789 rx_data->rbd_next = 0; 1790 1791 /* 1792 * Setup the Receive Descriptor Control Register (RXDCTL) 1793 * PTHRESH=32 descriptors (half the internal cache) 1794 * HTHRESH=0 descriptors (to minimize latency on fetch) 1795 * WTHRESH defaults to 1 (writeback each descriptor) 1796 */ 1797 reg_val = IXGBE_READ_REG(hw, IXGBE_RXDCTL(rx_ring->index)); 1798 reg_val |= IXGBE_RXDCTL_ENABLE; /* enable queue */ 1799 1800 /* Not a valid value for 82599 */ 1801 if (hw->mac.type < ixgbe_mac_82599EB) { 1802 reg_val |= 0x0020; /* pthresh */ 1803 } 1804 IXGBE_WRITE_REG(hw, IXGBE_RXDCTL(rx_ring->index), reg_val); 1805 1806 if (hw->mac.type == ixgbe_mac_82599EB) { 1807 reg_val = IXGBE_READ_REG(hw, IXGBE_RDRXCTL); 1808 reg_val |= (IXGBE_RDRXCTL_CRCSTRIP | IXGBE_RDRXCTL_AGGDIS); 1809 IXGBE_WRITE_REG(hw, IXGBE_RDRXCTL, reg_val); 1810 } 1811 1812 /* 1813 * Setup the Split and Replication Receive Control Register. 1814 * Set the rx buffer size and the advanced descriptor type. 1815 */ 1816 reg_val = (ixgbe->rx_buf_size >> IXGBE_SRRCTL_BSIZEPKT_SHIFT) | 1817 IXGBE_SRRCTL_DESCTYPE_ADV_ONEBUF; 1818 reg_val |= IXGBE_SRRCTL_DROP_EN; 1819 IXGBE_WRITE_REG(hw, IXGBE_SRRCTL(rx_ring->index), reg_val); 1820 } 1821 1822 static void 1823 ixgbe_setup_rx(ixgbe_t *ixgbe) 1824 { 1825 ixgbe_rx_ring_t *rx_ring; 1826 struct ixgbe_hw *hw = &ixgbe->hw; 1827 ixgbe_rx_group_t *rx_group; 1828 uint32_t reg_val; 1829 uint32_t ring_mapping; 1830 int i; 1831 1832 /* PSRTYPE must be configured for 82599 */ 1833 reg_val = IXGBE_PSRTYPE_TCPHDR | IXGBE_PSRTYPE_UDPHDR | 1834 IXGBE_PSRTYPE_IPV4HDR | IXGBE_PSRTYPE_IPV6HDR; 1835 #define IXGBE_PSRTYPE_L2_PKT 0x00001000 1836 reg_val |= IXGBE_PSRTYPE_L2_PKT; 1837 reg_val |= 0xE0000000; 1838 IXGBE_WRITE_REG(hw, IXGBE_PSRTYPE(0), reg_val); 1839 1840 /* 1841 * Set filter control in FCTRL to accept broadcast packets and do 1842 * not pass pause frames to host. Flow control settings are already 1843 * in this register, so preserve them. 1844 */ 1845 reg_val = IXGBE_READ_REG(hw, IXGBE_FCTRL); 1846 reg_val |= IXGBE_FCTRL_BAM; /* broadcast accept mode */ 1847 reg_val |= IXGBE_FCTRL_DPF; /* discard pause frames */ 1848 IXGBE_WRITE_REG(hw, IXGBE_FCTRL, reg_val); 1849 1850 /* 1851 * Enable the receive unit. This must be done after filter 1852 * control is set in FCTRL. 1853 */ 1854 reg_val = (IXGBE_RXCTRL_RXEN /* Enable Receive Unit */ 1855 | IXGBE_RXCTRL_DMBYPS); /* descriptor monitor bypass */ 1856 IXGBE_WRITE_REG(hw, IXGBE_RXCTRL, reg_val); 1857 1858 /* 1859 * ixgbe_setup_rx_ring must be called after configuring RXCTRL 1860 */ 1861 for (i = 0; i < ixgbe->num_rx_rings; i++) { 1862 rx_ring = &ixgbe->rx_rings[i]; 1863 ixgbe_setup_rx_ring(rx_ring); 1864 } 1865 1866 /* 1867 * Setup rx groups. 1868 */ 1869 for (i = 0; i < ixgbe->num_rx_groups; i++) { 1870 rx_group = &ixgbe->rx_groups[i]; 1871 rx_group->index = i; 1872 rx_group->ixgbe = ixgbe; 1873 } 1874 1875 /* 1876 * Setup the per-ring statistics mapping. 1877 */ 1878 ring_mapping = 0; 1879 for (i = 0; i < ixgbe->num_rx_rings; i++) { 1880 ring_mapping |= (i & 0xF) << (8 * (i & 0x3)); 1881 if ((i & 0x3) == 0x3) { 1882 IXGBE_WRITE_REG(hw, IXGBE_RQSMR(i >> 2), ring_mapping); 1883 ring_mapping = 0; 1884 } 1885 } 1886 if ((i & 0x3) != 0x3) 1887 IXGBE_WRITE_REG(hw, IXGBE_RQSMR(i >> 2), ring_mapping); 1888 1889 /* 1890 * The Max Frame Size in MHADD/MAXFRS will be internally increased 1891 * by four bytes if the packet has a VLAN field, so includes MTU, 1892 * ethernet header and frame check sequence. 1893 * Register is MAXFRS in 82599. 1894 */ 1895 reg_val = (ixgbe->default_mtu + sizeof (struct ether_header) 1896 + ETHERFCSL) << IXGBE_MHADD_MFS_SHIFT; 1897 IXGBE_WRITE_REG(hw, IXGBE_MHADD, reg_val); 1898 1899 /* 1900 * Setup Jumbo Frame enable bit 1901 */ 1902 if (ixgbe->default_mtu > ETHERMTU) { 1903 reg_val = IXGBE_READ_REG(hw, IXGBE_HLREG0); 1904 reg_val |= IXGBE_HLREG0_JUMBOEN; 1905 IXGBE_WRITE_REG(hw, IXGBE_HLREG0, reg_val); 1906 } 1907 1908 /* 1909 * Hardware checksum settings 1910 */ 1911 if (ixgbe->rx_hcksum_enable) { 1912 reg_val = IXGBE_RXCSUM_IPPCSE; /* IP checksum */ 1913 IXGBE_WRITE_REG(hw, IXGBE_RXCSUM, reg_val); 1914 } 1915 1916 /* 1917 * Setup RSS for multiple receive queues 1918 */ 1919 if (ixgbe->num_rx_rings > 1) 1920 ixgbe_setup_rss(ixgbe); 1921 } 1922 1923 static void 1924 ixgbe_setup_tx_ring(ixgbe_tx_ring_t *tx_ring) 1925 { 1926 ixgbe_t *ixgbe = tx_ring->ixgbe; 1927 struct ixgbe_hw *hw = &ixgbe->hw; 1928 uint32_t size; 1929 uint32_t buf_low; 1930 uint32_t buf_high; 1931 uint32_t reg_val; 1932 1933 ASSERT(mutex_owned(&tx_ring->tx_lock)); 1934 ASSERT(mutex_owned(&ixgbe->gen_lock)); 1935 1936 /* 1937 * Initialize the length register 1938 */ 1939 size = tx_ring->ring_size * sizeof (union ixgbe_adv_tx_desc); 1940 IXGBE_WRITE_REG(hw, IXGBE_TDLEN(tx_ring->index), size); 1941 1942 /* 1943 * Initialize the base address registers 1944 */ 1945 buf_low = (uint32_t)tx_ring->tbd_area.dma_address; 1946 buf_high = (uint32_t)(tx_ring->tbd_area.dma_address >> 32); 1947 IXGBE_WRITE_REG(hw, IXGBE_TDBAL(tx_ring->index), buf_low); 1948 IXGBE_WRITE_REG(hw, IXGBE_TDBAH(tx_ring->index), buf_high); 1949 1950 /* 1951 * Setup head & tail pointers 1952 */ 1953 IXGBE_WRITE_REG(hw, IXGBE_TDH(tx_ring->index), 0); 1954 IXGBE_WRITE_REG(hw, IXGBE_TDT(tx_ring->index), 0); 1955 1956 /* 1957 * Setup head write-back 1958 */ 1959 if (ixgbe->tx_head_wb_enable) { 1960 /* 1961 * The memory of the head write-back is allocated using 1962 * the extra tbd beyond the tail of the tbd ring. 1963 */ 1964 tx_ring->tbd_head_wb = (uint32_t *) 1965 ((uintptr_t)tx_ring->tbd_area.address + size); 1966 *tx_ring->tbd_head_wb = 0; 1967 1968 buf_low = (uint32_t) 1969 (tx_ring->tbd_area.dma_address + size); 1970 buf_high = (uint32_t) 1971 ((tx_ring->tbd_area.dma_address + size) >> 32); 1972 1973 /* Set the head write-back enable bit */ 1974 buf_low |= IXGBE_TDWBAL_HEAD_WB_ENABLE; 1975 1976 IXGBE_WRITE_REG(hw, IXGBE_TDWBAL(tx_ring->index), buf_low); 1977 IXGBE_WRITE_REG(hw, IXGBE_TDWBAH(tx_ring->index), buf_high); 1978 1979 /* 1980 * Turn off relaxed ordering for head write back or it will 1981 * cause problems with the tx recycling 1982 */ 1983 reg_val = IXGBE_READ_REG(hw, 1984 IXGBE_DCA_TXCTRL(tx_ring->index)); 1985 reg_val &= ~IXGBE_DCA_TXCTRL_TX_WB_RO_EN; 1986 IXGBE_WRITE_REG(hw, 1987 IXGBE_DCA_TXCTRL(tx_ring->index), reg_val); 1988 } else { 1989 tx_ring->tbd_head_wb = NULL; 1990 } 1991 1992 tx_ring->tbd_head = 0; 1993 tx_ring->tbd_tail = 0; 1994 tx_ring->tbd_free = tx_ring->ring_size; 1995 1996 if (ixgbe->tx_ring_init == B_TRUE) { 1997 tx_ring->tcb_head = 0; 1998 tx_ring->tcb_tail = 0; 1999 tx_ring->tcb_free = tx_ring->free_list_size; 2000 } 2001 2002 /* 2003 * Initialize the s/w context structure 2004 */ 2005 bzero(&tx_ring->tx_context, sizeof (ixgbe_tx_context_t)); 2006 } 2007 2008 static void 2009 ixgbe_setup_tx(ixgbe_t *ixgbe) 2010 { 2011 struct ixgbe_hw *hw = &ixgbe->hw; 2012 ixgbe_tx_ring_t *tx_ring; 2013 uint32_t reg_val; 2014 uint32_t ring_mapping; 2015 int i; 2016 2017 for (i = 0; i < ixgbe->num_tx_rings; i++) { 2018 tx_ring = &ixgbe->tx_rings[i]; 2019 ixgbe_setup_tx_ring(tx_ring); 2020 } 2021 2022 /* 2023 * Setup the per-ring statistics mapping. 2024 */ 2025 ring_mapping = 0; 2026 for (i = 0; i < ixgbe->num_tx_rings; i++) { 2027 ring_mapping |= (i & 0xF) << (8 * (i & 0x3)); 2028 if ((i & 0x3) == 0x3) { 2029 if (hw->mac.type >= ixgbe_mac_82599EB) { 2030 IXGBE_WRITE_REG(hw, IXGBE_TQSM(i >> 2), 2031 ring_mapping); 2032 } else { 2033 IXGBE_WRITE_REG(hw, IXGBE_TQSMR(i >> 2), 2034 ring_mapping); 2035 } 2036 ring_mapping = 0; 2037 } 2038 } 2039 if ((i & 0x3) != 0x3) 2040 if (hw->mac.type >= ixgbe_mac_82599EB) { 2041 IXGBE_WRITE_REG(hw, IXGBE_TQSM(i >> 2), ring_mapping); 2042 } else { 2043 IXGBE_WRITE_REG(hw, IXGBE_TQSMR(i >> 2), ring_mapping); 2044 } 2045 2046 /* 2047 * Enable CRC appending and TX padding (for short tx frames) 2048 */ 2049 reg_val = IXGBE_READ_REG(hw, IXGBE_HLREG0); 2050 reg_val |= IXGBE_HLREG0_TXCRCEN | IXGBE_HLREG0_TXPADEN; 2051 IXGBE_WRITE_REG(hw, IXGBE_HLREG0, reg_val); 2052 2053 /* 2054 * enable DMA for 82599 parts 2055 */ 2056 if (hw->mac.type == ixgbe_mac_82599EB) { 2057 /* DMATXCTL.TE must be set after all Tx config is complete */ 2058 reg_val = IXGBE_READ_REG(hw, IXGBE_DMATXCTL); 2059 reg_val |= IXGBE_DMATXCTL_TE; 2060 IXGBE_WRITE_REG(hw, IXGBE_DMATXCTL, reg_val); 2061 } 2062 2063 /* 2064 * Enabling tx queues .. 2065 * For 82599 must be done after DMATXCTL.TE is set 2066 */ 2067 for (i = 0; i < ixgbe->num_tx_rings; i++) { 2068 tx_ring = &ixgbe->tx_rings[i]; 2069 reg_val = IXGBE_READ_REG(hw, IXGBE_TXDCTL(tx_ring->index)); 2070 reg_val |= IXGBE_TXDCTL_ENABLE; 2071 IXGBE_WRITE_REG(hw, IXGBE_TXDCTL(tx_ring->index), reg_val); 2072 } 2073 } 2074 2075 /* 2076 * ixgbe_setup_rss - Setup receive-side scaling feature. 2077 */ 2078 static void 2079 ixgbe_setup_rss(ixgbe_t *ixgbe) 2080 { 2081 struct ixgbe_hw *hw = &ixgbe->hw; 2082 uint32_t i, mrqc, rxcsum; 2083 uint32_t random; 2084 uint32_t reta; 2085 2086 /* 2087 * Fill out redirection table 2088 */ 2089 reta = 0; 2090 for (i = 0; i < 128; i++) { 2091 reta = (reta << 8) | (i % ixgbe->num_rx_rings); 2092 if ((i & 3) == 3) 2093 IXGBE_WRITE_REG(hw, IXGBE_RETA(i >> 2), reta); 2094 } 2095 2096 /* 2097 * Fill out hash function seeds with a random constant 2098 */ 2099 for (i = 0; i < 10; i++) { 2100 (void) random_get_pseudo_bytes((uint8_t *)&random, 2101 sizeof (uint32_t)); 2102 IXGBE_WRITE_REG(hw, IXGBE_RSSRK(i), random); 2103 } 2104 2105 /* 2106 * Enable RSS & perform hash on these packet types 2107 */ 2108 mrqc = IXGBE_MRQC_RSSEN | 2109 IXGBE_MRQC_RSS_FIELD_IPV4 | 2110 IXGBE_MRQC_RSS_FIELD_IPV4_TCP | 2111 IXGBE_MRQC_RSS_FIELD_IPV4_UDP | 2112 IXGBE_MRQC_RSS_FIELD_IPV6_EX_TCP | 2113 IXGBE_MRQC_RSS_FIELD_IPV6_EX | 2114 IXGBE_MRQC_RSS_FIELD_IPV6 | 2115 IXGBE_MRQC_RSS_FIELD_IPV6_TCP | 2116 IXGBE_MRQC_RSS_FIELD_IPV6_UDP | 2117 IXGBE_MRQC_RSS_FIELD_IPV6_EX_UDP; 2118 IXGBE_WRITE_REG(hw, IXGBE_MRQC, mrqc); 2119 2120 /* 2121 * Disable Packet Checksum to enable RSS for multiple receive queues. 2122 * It is an adapter hardware limitation that Packet Checksum is 2123 * mutually exclusive with RSS. 2124 */ 2125 rxcsum = IXGBE_READ_REG(hw, IXGBE_RXCSUM); 2126 rxcsum |= IXGBE_RXCSUM_PCSD; 2127 rxcsum &= ~IXGBE_RXCSUM_IPPCSE; 2128 IXGBE_WRITE_REG(hw, IXGBE_RXCSUM, rxcsum); 2129 } 2130 2131 /* 2132 * ixgbe_init_unicst - Initialize the unicast addresses. 2133 */ 2134 static void 2135 ixgbe_init_unicst(ixgbe_t *ixgbe) 2136 { 2137 struct ixgbe_hw *hw = &ixgbe->hw; 2138 uint8_t *mac_addr; 2139 int slot; 2140 /* 2141 * Here we should consider two situations: 2142 * 2143 * 1. Chipset is initialized at the first time, 2144 * Clear all the multiple unicast addresses. 2145 * 2146 * 2. Chipset is reset 2147 * Recover the multiple unicast addresses from the 2148 * software data structure to the RAR registers. 2149 */ 2150 if (!ixgbe->unicst_init) { 2151 /* 2152 * Initialize the multiple unicast addresses 2153 */ 2154 ixgbe->unicst_total = MAX_NUM_UNICAST_ADDRESSES; 2155 ixgbe->unicst_avail = ixgbe->unicst_total; 2156 for (slot = 0; slot < ixgbe->unicst_total; slot++) { 2157 mac_addr = ixgbe->unicst_addr[slot].mac.addr; 2158 bzero(mac_addr, ETHERADDRL); 2159 (void) ixgbe_set_rar(hw, slot, mac_addr, NULL, NULL); 2160 ixgbe->unicst_addr[slot].mac.set = 0; 2161 } 2162 ixgbe->unicst_init = B_TRUE; 2163 } else { 2164 /* Re-configure the RAR registers */ 2165 for (slot = 0; slot < ixgbe->unicst_total; slot++) { 2166 mac_addr = ixgbe->unicst_addr[slot].mac.addr; 2167 if (ixgbe->unicst_addr[slot].mac.set == 1) { 2168 (void) ixgbe_set_rar(hw, slot, mac_addr, 2169 NULL, IXGBE_RAH_AV); 2170 } else { 2171 bzero(mac_addr, ETHERADDRL); 2172 (void) ixgbe_set_rar(hw, slot, mac_addr, 2173 NULL, NULL); 2174 } 2175 } 2176 } 2177 } 2178 2179 /* 2180 * ixgbe_unicst_set - Set the unicast address to the specified slot. 2181 */ 2182 int 2183 ixgbe_unicst_set(ixgbe_t *ixgbe, const uint8_t *mac_addr, 2184 int slot) 2185 { 2186 struct ixgbe_hw *hw = &ixgbe->hw; 2187 2188 ASSERT(mutex_owned(&ixgbe->gen_lock)); 2189 2190 /* 2191 * Save the unicast address in the software data structure 2192 */ 2193 bcopy(mac_addr, ixgbe->unicst_addr[slot].mac.addr, ETHERADDRL); 2194 2195 /* 2196 * Set the unicast address to the RAR register 2197 */ 2198 (void) ixgbe_set_rar(hw, slot, (uint8_t *)mac_addr, NULL, IXGBE_RAH_AV); 2199 2200 if (ixgbe_check_acc_handle(ixgbe->osdep.reg_handle) != DDI_FM_OK) { 2201 ddi_fm_service_impact(ixgbe->dip, DDI_SERVICE_DEGRADED); 2202 return (EIO); 2203 } 2204 2205 return (0); 2206 } 2207 2208 /* 2209 * ixgbe_unicst_find - Find the slot for the specified unicast address 2210 */ 2211 int 2212 ixgbe_unicst_find(ixgbe_t *ixgbe, const uint8_t *mac_addr) 2213 { 2214 int slot; 2215 2216 ASSERT(mutex_owned(&ixgbe->gen_lock)); 2217 2218 for (slot = 0; slot < ixgbe->unicst_total; slot++) { 2219 if (bcmp(ixgbe->unicst_addr[slot].mac.addr, 2220 mac_addr, ETHERADDRL) == 0) 2221 return (slot); 2222 } 2223 2224 return (-1); 2225 } 2226 2227 /* 2228 * ixgbe_multicst_add - Add a multicst address. 2229 */ 2230 int 2231 ixgbe_multicst_add(ixgbe_t *ixgbe, const uint8_t *multiaddr) 2232 { 2233 ASSERT(mutex_owned(&ixgbe->gen_lock)); 2234 2235 if ((multiaddr[0] & 01) == 0) { 2236 return (EINVAL); 2237 } 2238 2239 if (ixgbe->mcast_count >= MAX_NUM_MULTICAST_ADDRESSES) { 2240 return (ENOENT); 2241 } 2242 2243 bcopy(multiaddr, 2244 &ixgbe->mcast_table[ixgbe->mcast_count], ETHERADDRL); 2245 ixgbe->mcast_count++; 2246 2247 /* 2248 * Update the multicast table in the hardware 2249 */ 2250 ixgbe_setup_multicst(ixgbe); 2251 2252 if (ixgbe_check_acc_handle(ixgbe->osdep.reg_handle) != DDI_FM_OK) { 2253 ddi_fm_service_impact(ixgbe->dip, DDI_SERVICE_DEGRADED); 2254 return (EIO); 2255 } 2256 2257 return (0); 2258 } 2259 2260 /* 2261 * ixgbe_multicst_remove - Remove a multicst address. 2262 */ 2263 int 2264 ixgbe_multicst_remove(ixgbe_t *ixgbe, const uint8_t *multiaddr) 2265 { 2266 int i; 2267 2268 ASSERT(mutex_owned(&ixgbe->gen_lock)); 2269 2270 for (i = 0; i < ixgbe->mcast_count; i++) { 2271 if (bcmp(multiaddr, &ixgbe->mcast_table[i], 2272 ETHERADDRL) == 0) { 2273 for (i++; i < ixgbe->mcast_count; i++) { 2274 ixgbe->mcast_table[i - 1] = 2275 ixgbe->mcast_table[i]; 2276 } 2277 ixgbe->mcast_count--; 2278 break; 2279 } 2280 } 2281 2282 /* 2283 * Update the multicast table in the hardware 2284 */ 2285 ixgbe_setup_multicst(ixgbe); 2286 2287 if (ixgbe_check_acc_handle(ixgbe->osdep.reg_handle) != DDI_FM_OK) { 2288 ddi_fm_service_impact(ixgbe->dip, DDI_SERVICE_DEGRADED); 2289 return (EIO); 2290 } 2291 2292 return (0); 2293 } 2294 2295 /* 2296 * ixgbe_setup_multicast - Setup multicast data structures. 2297 * 2298 * This routine initializes all of the multicast related structures 2299 * and save them in the hardware registers. 2300 */ 2301 static void 2302 ixgbe_setup_multicst(ixgbe_t *ixgbe) 2303 { 2304 uint8_t *mc_addr_list; 2305 uint32_t mc_addr_count; 2306 struct ixgbe_hw *hw = &ixgbe->hw; 2307 2308 ASSERT(mutex_owned(&ixgbe->gen_lock)); 2309 2310 ASSERT(ixgbe->mcast_count <= MAX_NUM_MULTICAST_ADDRESSES); 2311 2312 mc_addr_list = (uint8_t *)ixgbe->mcast_table; 2313 mc_addr_count = ixgbe->mcast_count; 2314 2315 /* 2316 * Update the multicast addresses to the MTA registers 2317 */ 2318 (void) ixgbe_update_mc_addr_list(hw, mc_addr_list, mc_addr_count, 2319 ixgbe_mc_table_itr); 2320 } 2321 2322 /* 2323 * ixgbe_get_conf - Get driver configurations set in driver.conf. 2324 * 2325 * This routine gets user-configured values out of the configuration 2326 * file ixgbe.conf. 2327 * 2328 * For each configurable value, there is a minimum, a maximum, and a 2329 * default. 2330 * If user does not configure a value, use the default. 2331 * If user configures below the minimum, use the minumum. 2332 * If user configures above the maximum, use the maxumum. 2333 */ 2334 static void 2335 ixgbe_get_conf(ixgbe_t *ixgbe) 2336 { 2337 struct ixgbe_hw *hw = &ixgbe->hw; 2338 uint32_t flow_control; 2339 2340 /* 2341 * ixgbe driver supports the following user configurations: 2342 * 2343 * Jumbo frame configuration: 2344 * default_mtu 2345 * 2346 * Ethernet flow control configuration: 2347 * flow_control 2348 * 2349 * Multiple rings configurations: 2350 * tx_queue_number 2351 * tx_ring_size 2352 * rx_queue_number 2353 * rx_ring_size 2354 * 2355 * Call ixgbe_get_prop() to get the value for a specific 2356 * configuration parameter. 2357 */ 2358 2359 /* 2360 * Jumbo frame configuration - max_frame_size controls host buffer 2361 * allocation, so includes MTU, ethernet header, vlan tag and 2362 * frame check sequence. 2363 */ 2364 ixgbe->default_mtu = ixgbe_get_prop(ixgbe, PROP_DEFAULT_MTU, 2365 MIN_MTU, ixgbe->capab->max_mtu, DEFAULT_MTU); 2366 2367 ixgbe->max_frame_size = ixgbe->default_mtu + 2368 sizeof (struct ether_vlan_header) + ETHERFCSL; 2369 2370 /* 2371 * Ethernet flow control configuration 2372 */ 2373 flow_control = ixgbe_get_prop(ixgbe, PROP_FLOW_CONTROL, 2374 ixgbe_fc_none, 3, ixgbe_fc_none); 2375 if (flow_control == 3) 2376 flow_control = ixgbe_fc_default; 2377 2378 /* 2379 * fc.requested mode is what the user requests. After autoneg, 2380 * fc.current_mode will be the flow_control mode that was negotiated. 2381 */ 2382 hw->fc.requested_mode = flow_control; 2383 2384 /* 2385 * Multiple rings configurations 2386 */ 2387 ixgbe->num_tx_rings = ixgbe_get_prop(ixgbe, PROP_TX_QUEUE_NUM, 2388 ixgbe->capab->min_tx_que_num, 2389 ixgbe->capab->max_tx_que_num, 2390 ixgbe->capab->def_tx_que_num); 2391 ixgbe->tx_ring_size = ixgbe_get_prop(ixgbe, PROP_TX_RING_SIZE, 2392 MIN_TX_RING_SIZE, MAX_TX_RING_SIZE, DEFAULT_TX_RING_SIZE); 2393 2394 ixgbe->num_rx_rings = ixgbe_get_prop(ixgbe, PROP_RX_QUEUE_NUM, 2395 ixgbe->capab->min_rx_que_num, 2396 ixgbe->capab->max_rx_que_num, 2397 ixgbe->capab->def_rx_que_num); 2398 ixgbe->rx_ring_size = ixgbe_get_prop(ixgbe, PROP_RX_RING_SIZE, 2399 MIN_RX_RING_SIZE, MAX_RX_RING_SIZE, DEFAULT_RX_RING_SIZE); 2400 2401 /* 2402 * Multiple groups configuration 2403 */ 2404 ixgbe->num_rx_groups = ixgbe_get_prop(ixgbe, PROP_RX_GROUP_NUM, 2405 MIN_RX_GROUP_NUM, MAX_RX_GROUP_NUM, DEFAULT_RX_GROUP_NUM); 2406 2407 ixgbe->mr_enable = ixgbe_get_prop(ixgbe, PROP_MR_ENABLE, 2408 0, 1, DEFAULT_MR_ENABLE); 2409 2410 if (ixgbe->mr_enable == B_FALSE) { 2411 ixgbe->num_tx_rings = 1; 2412 ixgbe->num_rx_rings = 1; 2413 ixgbe->num_rx_groups = 1; 2414 } 2415 2416 /* 2417 * Tunable used to force an interrupt type. The only use is 2418 * for testing of the lesser interrupt types. 2419 * 0 = don't force interrupt type 2420 * 1 = force interrupt type MSI-X 2421 * 2 = force interrupt type MSI 2422 * 3 = force interrupt type Legacy 2423 */ 2424 ixgbe->intr_force = ixgbe_get_prop(ixgbe, PROP_INTR_FORCE, 2425 IXGBE_INTR_NONE, IXGBE_INTR_LEGACY, IXGBE_INTR_NONE); 2426 2427 ixgbe->tx_hcksum_enable = ixgbe_get_prop(ixgbe, PROP_TX_HCKSUM_ENABLE, 2428 0, 1, DEFAULT_TX_HCKSUM_ENABLE); 2429 ixgbe->rx_hcksum_enable = ixgbe_get_prop(ixgbe, PROP_RX_HCKSUM_ENABLE, 2430 0, 1, DEFAULT_RX_HCKSUM_ENABLE); 2431 ixgbe->lso_enable = ixgbe_get_prop(ixgbe, PROP_LSO_ENABLE, 2432 0, 1, DEFAULT_LSO_ENABLE); 2433 ixgbe->tx_head_wb_enable = ixgbe_get_prop(ixgbe, PROP_TX_HEAD_WB_ENABLE, 2434 0, 1, DEFAULT_TX_HEAD_WB_ENABLE); 2435 2436 /* Head Write Back not recommended for 82599 */ 2437 if (hw->mac.type >= ixgbe_mac_82599EB) { 2438 ixgbe->tx_head_wb_enable = B_FALSE; 2439 } 2440 2441 /* 2442 * ixgbe LSO needs the tx h/w checksum support. 2443 * LSO will be disabled if tx h/w checksum is not 2444 * enabled. 2445 */ 2446 if (ixgbe->tx_hcksum_enable == B_FALSE) { 2447 ixgbe->lso_enable = B_FALSE; 2448 } 2449 2450 ixgbe->tx_copy_thresh = ixgbe_get_prop(ixgbe, PROP_TX_COPY_THRESHOLD, 2451 MIN_TX_COPY_THRESHOLD, MAX_TX_COPY_THRESHOLD, 2452 DEFAULT_TX_COPY_THRESHOLD); 2453 ixgbe->tx_recycle_thresh = ixgbe_get_prop(ixgbe, 2454 PROP_TX_RECYCLE_THRESHOLD, MIN_TX_RECYCLE_THRESHOLD, 2455 MAX_TX_RECYCLE_THRESHOLD, DEFAULT_TX_RECYCLE_THRESHOLD); 2456 ixgbe->tx_overload_thresh = ixgbe_get_prop(ixgbe, 2457 PROP_TX_OVERLOAD_THRESHOLD, MIN_TX_OVERLOAD_THRESHOLD, 2458 MAX_TX_OVERLOAD_THRESHOLD, DEFAULT_TX_OVERLOAD_THRESHOLD); 2459 ixgbe->tx_resched_thresh = ixgbe_get_prop(ixgbe, 2460 PROP_TX_RESCHED_THRESHOLD, MIN_TX_RESCHED_THRESHOLD, 2461 MAX_TX_RESCHED_THRESHOLD, DEFAULT_TX_RESCHED_THRESHOLD); 2462 2463 ixgbe->rx_copy_thresh = ixgbe_get_prop(ixgbe, PROP_RX_COPY_THRESHOLD, 2464 MIN_RX_COPY_THRESHOLD, MAX_RX_COPY_THRESHOLD, 2465 DEFAULT_RX_COPY_THRESHOLD); 2466 ixgbe->rx_limit_per_intr = ixgbe_get_prop(ixgbe, PROP_RX_LIMIT_PER_INTR, 2467 MIN_RX_LIMIT_PER_INTR, MAX_RX_LIMIT_PER_INTR, 2468 DEFAULT_RX_LIMIT_PER_INTR); 2469 2470 ixgbe->intr_throttling[0] = ixgbe_get_prop(ixgbe, PROP_INTR_THROTTLING, 2471 ixgbe->capab->min_intr_throttle, 2472 ixgbe->capab->max_intr_throttle, 2473 ixgbe->capab->def_intr_throttle); 2474 /* 2475 * 82599 requires the interupt throttling rate is 2476 * a multiple of 8. This is enforced by the register 2477 * definiton. 2478 */ 2479 if (hw->mac.type == ixgbe_mac_82599EB) 2480 ixgbe->intr_throttling[0] = ixgbe->intr_throttling[0] & 0xFF8; 2481 } 2482 2483 static void 2484 ixgbe_init_params(ixgbe_t *ixgbe) 2485 { 2486 ixgbe->param_en_10000fdx_cap = 1; 2487 ixgbe->param_en_1000fdx_cap = 1; 2488 ixgbe->param_en_100fdx_cap = 1; 2489 ixgbe->param_adv_10000fdx_cap = 1; 2490 ixgbe->param_adv_1000fdx_cap = 1; 2491 ixgbe->param_adv_100fdx_cap = 1; 2492 2493 ixgbe->param_pause_cap = 1; 2494 ixgbe->param_asym_pause_cap = 1; 2495 ixgbe->param_rem_fault = 0; 2496 2497 ixgbe->param_adv_autoneg_cap = 1; 2498 ixgbe->param_adv_pause_cap = 1; 2499 ixgbe->param_adv_asym_pause_cap = 1; 2500 ixgbe->param_adv_rem_fault = 0; 2501 2502 ixgbe->param_lp_10000fdx_cap = 0; 2503 ixgbe->param_lp_1000fdx_cap = 0; 2504 ixgbe->param_lp_100fdx_cap = 0; 2505 ixgbe->param_lp_autoneg_cap = 0; 2506 ixgbe->param_lp_pause_cap = 0; 2507 ixgbe->param_lp_asym_pause_cap = 0; 2508 ixgbe->param_lp_rem_fault = 0; 2509 } 2510 2511 /* 2512 * ixgbe_get_prop - Get a property value out of the configuration file 2513 * ixgbe.conf. 2514 * 2515 * Caller provides the name of the property, a default value, a minimum 2516 * value, and a maximum value. 2517 * 2518 * Return configured value of the property, with default, minimum and 2519 * maximum properly applied. 2520 */ 2521 static int 2522 ixgbe_get_prop(ixgbe_t *ixgbe, 2523 char *propname, /* name of the property */ 2524 int minval, /* minimum acceptable value */ 2525 int maxval, /* maximim acceptable value */ 2526 int defval) /* default value */ 2527 { 2528 int value; 2529 2530 /* 2531 * Call ddi_prop_get_int() to read the conf settings 2532 */ 2533 value = ddi_prop_get_int(DDI_DEV_T_ANY, ixgbe->dip, 2534 DDI_PROP_DONTPASS, propname, defval); 2535 if (value > maxval) 2536 value = maxval; 2537 2538 if (value < minval) 2539 value = minval; 2540 2541 return (value); 2542 } 2543 2544 /* 2545 * ixgbe_driver_setup_link - Using the link properties to setup the link. 2546 */ 2547 int 2548 ixgbe_driver_setup_link(ixgbe_t *ixgbe, boolean_t setup_hw) 2549 { 2550 u32 autoneg_advertised = 0; 2551 2552 /* 2553 * No half duplex support with 10Gb parts 2554 */ 2555 if (ixgbe->param_adv_10000fdx_cap == 1) 2556 autoneg_advertised |= IXGBE_LINK_SPEED_10GB_FULL; 2557 2558 if (ixgbe->param_adv_1000fdx_cap == 1) 2559 autoneg_advertised |= IXGBE_LINK_SPEED_1GB_FULL; 2560 2561 if (ixgbe->param_adv_100fdx_cap == 1) 2562 autoneg_advertised |= IXGBE_LINK_SPEED_100_FULL; 2563 2564 if (ixgbe->param_adv_autoneg_cap == 1 && autoneg_advertised == 0) { 2565 ixgbe_notice(ixgbe, "Invalid link settings. Setup link " 2566 "to autonegotiation with full link capabilities."); 2567 2568 autoneg_advertised = IXGBE_LINK_SPEED_10GB_FULL | 2569 IXGBE_LINK_SPEED_1GB_FULL | 2570 IXGBE_LINK_SPEED_100_FULL; 2571 } 2572 2573 if (setup_hw) { 2574 if (ixgbe_setup_link(&ixgbe->hw, autoneg_advertised, 2575 ixgbe->param_adv_autoneg_cap, B_TRUE) != IXGBE_SUCCESS) { 2576 ixgbe_notice(ixgbe, "Setup link failed on this " 2577 "device."); 2578 return (IXGBE_FAILURE); 2579 } 2580 } 2581 2582 return (IXGBE_SUCCESS); 2583 } 2584 2585 /* 2586 * ixgbe_driver_link_check - Link status processing. 2587 * 2588 * This function can be called in both kernel context and interrupt context 2589 */ 2590 static void 2591 ixgbe_driver_link_check(ixgbe_t *ixgbe) 2592 { 2593 struct ixgbe_hw *hw = &ixgbe->hw; 2594 ixgbe_link_speed speed = IXGBE_LINK_SPEED_UNKNOWN; 2595 boolean_t link_up = B_FALSE; 2596 boolean_t link_changed = B_FALSE; 2597 2598 ASSERT(mutex_owned(&ixgbe->gen_lock)); 2599 2600 (void) ixgbe_check_link(hw, &speed, &link_up, false); 2601 if (link_up) { 2602 ixgbe->link_check_complete = B_TRUE; 2603 2604 /* Link is up, enable flow control settings */ 2605 (void) ixgbe_fc_enable(hw, 0); 2606 2607 /* 2608 * The Link is up, check whether it was marked as down earlier 2609 */ 2610 if (ixgbe->link_state != LINK_STATE_UP) { 2611 switch (speed) { 2612 case IXGBE_LINK_SPEED_10GB_FULL: 2613 ixgbe->link_speed = SPEED_10GB; 2614 break; 2615 case IXGBE_LINK_SPEED_1GB_FULL: 2616 ixgbe->link_speed = SPEED_1GB; 2617 break; 2618 case IXGBE_LINK_SPEED_100_FULL: 2619 ixgbe->link_speed = SPEED_100; 2620 } 2621 ixgbe->link_duplex = LINK_DUPLEX_FULL; 2622 ixgbe->link_state = LINK_STATE_UP; 2623 ixgbe->link_down_timeout = 0; 2624 link_changed = B_TRUE; 2625 } 2626 } else { 2627 if (ixgbe->link_check_complete == B_TRUE || 2628 (ixgbe->link_check_complete == B_FALSE && 2629 gethrtime() >= ixgbe->link_check_hrtime)) { 2630 /* 2631 * The link is really down 2632 */ 2633 ixgbe->link_check_complete = B_TRUE; 2634 2635 if (ixgbe->link_state != LINK_STATE_DOWN) { 2636 ixgbe->link_speed = 0; 2637 ixgbe->link_duplex = LINK_DUPLEX_UNKNOWN; 2638 ixgbe->link_state = LINK_STATE_DOWN; 2639 link_changed = B_TRUE; 2640 } 2641 2642 if (ixgbe->ixgbe_state & IXGBE_STARTED) { 2643 if (ixgbe->link_down_timeout < 2644 MAX_LINK_DOWN_TIMEOUT) { 2645 ixgbe->link_down_timeout++; 2646 } else if (ixgbe->link_down_timeout == 2647 MAX_LINK_DOWN_TIMEOUT) { 2648 ixgbe_tx_clean(ixgbe); 2649 ixgbe->link_down_timeout++; 2650 } 2651 } 2652 } 2653 } 2654 2655 /* 2656 * this is only reached after a link-status-change interrupt 2657 * so always get new phy state 2658 */ 2659 ixgbe_get_hw_state(ixgbe); 2660 2661 /* 2662 * If we are in an interrupt context, need to re-enable the 2663 * interrupt, which was automasked 2664 */ 2665 if (servicing_interrupt() != 0) { 2666 ixgbe->eims |= IXGBE_EICR_LSC; 2667 IXGBE_WRITE_REG(hw, IXGBE_EIMS, ixgbe->eims); 2668 } 2669 2670 if (link_changed) { 2671 mac_link_update(ixgbe->mac_hdl, ixgbe->link_state); 2672 } 2673 } 2674 2675 /* 2676 * ixgbe_sfp_check - sfp module processing done in taskq only for 82599. 2677 */ 2678 static void 2679 ixgbe_sfp_check(void *arg) 2680 { 2681 ixgbe_t *ixgbe = (ixgbe_t *)arg; 2682 uint32_t eicr = ixgbe->eicr; 2683 struct ixgbe_hw *hw = &ixgbe->hw; 2684 2685 mutex_enter(&ixgbe->gen_lock); 2686 if (eicr & IXGBE_EICR_GPI_SDP1) { 2687 /* clear the interrupt */ 2688 IXGBE_WRITE_REG(hw, IXGBE_EICR, IXGBE_EICR_GPI_SDP1); 2689 2690 /* if link up, do multispeed fiber setup */ 2691 (void) ixgbe_setup_link(hw, IXGBE_LINK_SPEED_82599_AUTONEG, 2692 B_TRUE, B_TRUE); 2693 ixgbe_driver_link_check(ixgbe); 2694 } else if (eicr & IXGBE_EICR_GPI_SDP2) { 2695 /* clear the interrupt */ 2696 IXGBE_WRITE_REG(hw, IXGBE_EICR, IXGBE_EICR_GPI_SDP2); 2697 2698 /* if link up, do sfp module setup */ 2699 (void) hw->mac.ops.setup_sfp(hw); 2700 2701 /* do multispeed fiber setup */ 2702 (void) ixgbe_setup_link(hw, IXGBE_LINK_SPEED_82599_AUTONEG, 2703 B_TRUE, B_TRUE); 2704 ixgbe_driver_link_check(ixgbe); 2705 } 2706 mutex_exit(&ixgbe->gen_lock); 2707 } 2708 2709 /* 2710 * ixgbe_link_timer - timer for link status detection 2711 */ 2712 static void 2713 ixgbe_link_timer(void *arg) 2714 { 2715 ixgbe_t *ixgbe = (ixgbe_t *)arg; 2716 2717 mutex_enter(&ixgbe->gen_lock); 2718 ixgbe_driver_link_check(ixgbe); 2719 mutex_exit(&ixgbe->gen_lock); 2720 } 2721 2722 /* 2723 * ixgbe_local_timer - Driver watchdog function. 2724 * 2725 * This function will handle the transmit stall check and other routines. 2726 */ 2727 static void 2728 ixgbe_local_timer(void *arg) 2729 { 2730 ixgbe_t *ixgbe = (ixgbe_t *)arg; 2731 2732 if (ixgbe->ixgbe_state & IXGBE_ERROR) { 2733 ixgbe->reset_count++; 2734 if (ixgbe_reset(ixgbe) == IXGBE_SUCCESS) 2735 ddi_fm_service_impact(ixgbe->dip, DDI_SERVICE_RESTORED); 2736 ixgbe_restart_watchdog_timer(ixgbe); 2737 return; 2738 } 2739 2740 if (ixgbe_stall_check(ixgbe)) { 2741 atomic_or_32(&ixgbe->ixgbe_state, IXGBE_STALL); 2742 ddi_fm_service_impact(ixgbe->dip, DDI_SERVICE_DEGRADED); 2743 2744 ixgbe->reset_count++; 2745 if (ixgbe_reset(ixgbe) == IXGBE_SUCCESS) 2746 ddi_fm_service_impact(ixgbe->dip, DDI_SERVICE_RESTORED); 2747 ixgbe_restart_watchdog_timer(ixgbe); 2748 } 2749 } 2750 2751 /* 2752 * ixgbe_stall_check - Check for transmit stall. 2753 * 2754 * This function checks if the adapter is stalled (in transmit). 2755 * 2756 * It is called each time the watchdog timeout is invoked. 2757 * If the transmit descriptor reclaim continuously fails, 2758 * the watchdog value will increment by 1. If the watchdog 2759 * value exceeds the threshold, the ixgbe is assumed to 2760 * have stalled and need to be reset. 2761 */ 2762 static boolean_t 2763 ixgbe_stall_check(ixgbe_t *ixgbe) 2764 { 2765 ixgbe_tx_ring_t *tx_ring; 2766 boolean_t result; 2767 int i; 2768 2769 if (ixgbe->link_state != LINK_STATE_UP) 2770 return (B_FALSE); 2771 2772 /* 2773 * If any tx ring is stalled, we'll reset the chipset 2774 */ 2775 result = B_FALSE; 2776 for (i = 0; i < ixgbe->num_tx_rings; i++) { 2777 tx_ring = &ixgbe->tx_rings[i]; 2778 if (tx_ring->tbd_free <= ixgbe->tx_recycle_thresh) { 2779 tx_ring->tx_recycle(tx_ring); 2780 } 2781 2782 if (tx_ring->recycle_fail > 0) 2783 tx_ring->stall_watchdog++; 2784 else 2785 tx_ring->stall_watchdog = 0; 2786 2787 if (tx_ring->stall_watchdog >= STALL_WATCHDOG_TIMEOUT) { 2788 result = B_TRUE; 2789 break; 2790 } 2791 } 2792 2793 if (result) { 2794 tx_ring->stall_watchdog = 0; 2795 tx_ring->recycle_fail = 0; 2796 } 2797 2798 return (result); 2799 } 2800 2801 2802 /* 2803 * is_valid_mac_addr - Check if the mac address is valid. 2804 */ 2805 static boolean_t 2806 is_valid_mac_addr(uint8_t *mac_addr) 2807 { 2808 const uint8_t addr_test1[6] = { 0, 0, 0, 0, 0, 0 }; 2809 const uint8_t addr_test2[6] = 2810 { 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF }; 2811 2812 if (!(bcmp(addr_test1, mac_addr, ETHERADDRL)) || 2813 !(bcmp(addr_test2, mac_addr, ETHERADDRL))) 2814 return (B_FALSE); 2815 2816 return (B_TRUE); 2817 } 2818 2819 static boolean_t 2820 ixgbe_find_mac_address(ixgbe_t *ixgbe) 2821 { 2822 #ifdef __sparc 2823 struct ixgbe_hw *hw = &ixgbe->hw; 2824 uchar_t *bytes; 2825 struct ether_addr sysaddr; 2826 uint_t nelts; 2827 int err; 2828 boolean_t found = B_FALSE; 2829 2830 /* 2831 * The "vendor's factory-set address" may already have 2832 * been extracted from the chip, but if the property 2833 * "local-mac-address" is set we use that instead. 2834 * 2835 * We check whether it looks like an array of 6 2836 * bytes (which it should, if OBP set it). If we can't 2837 * make sense of it this way, we'll ignore it. 2838 */ 2839 err = ddi_prop_lookup_byte_array(DDI_DEV_T_ANY, ixgbe->dip, 2840 DDI_PROP_DONTPASS, "local-mac-address", &bytes, &nelts); 2841 if (err == DDI_PROP_SUCCESS) { 2842 if (nelts == ETHERADDRL) { 2843 while (nelts--) 2844 hw->mac.addr[nelts] = bytes[nelts]; 2845 found = B_TRUE; 2846 } 2847 ddi_prop_free(bytes); 2848 } 2849 2850 /* 2851 * Look up the OBP property "local-mac-address?". If the user has set 2852 * 'local-mac-address? = false', use "the system address" instead. 2853 */ 2854 if (ddi_prop_lookup_byte_array(DDI_DEV_T_ANY, ixgbe->dip, 0, 2855 "local-mac-address?", &bytes, &nelts) == DDI_PROP_SUCCESS) { 2856 if (strncmp("false", (caddr_t)bytes, (size_t)nelts) == 0) { 2857 if (localetheraddr(NULL, &sysaddr) != 0) { 2858 bcopy(&sysaddr, hw->mac.addr, ETHERADDRL); 2859 found = B_TRUE; 2860 } 2861 } 2862 ddi_prop_free(bytes); 2863 } 2864 2865 /* 2866 * Finally(!), if there's a valid "mac-address" property (created 2867 * if we netbooted from this interface), we must use this instead 2868 * of any of the above to ensure that the NFS/install server doesn't 2869 * get confused by the address changing as Solaris takes over! 2870 */ 2871 err = ddi_prop_lookup_byte_array(DDI_DEV_T_ANY, ixgbe->dip, 2872 DDI_PROP_DONTPASS, "mac-address", &bytes, &nelts); 2873 if (err == DDI_PROP_SUCCESS) { 2874 if (nelts == ETHERADDRL) { 2875 while (nelts--) 2876 hw->mac.addr[nelts] = bytes[nelts]; 2877 found = B_TRUE; 2878 } 2879 ddi_prop_free(bytes); 2880 } 2881 2882 if (found) { 2883 bcopy(hw->mac.addr, hw->mac.perm_addr, ETHERADDRL); 2884 return (B_TRUE); 2885 } 2886 #else 2887 _NOTE(ARGUNUSED(ixgbe)); 2888 #endif 2889 2890 return (B_TRUE); 2891 } 2892 2893 #pragma inline(ixgbe_arm_watchdog_timer) 2894 static void 2895 ixgbe_arm_watchdog_timer(ixgbe_t *ixgbe) 2896 { 2897 /* 2898 * Fire a watchdog timer 2899 */ 2900 ixgbe->watchdog_tid = 2901 timeout(ixgbe_local_timer, 2902 (void *)ixgbe, 1 * drv_usectohz(1000000)); 2903 2904 } 2905 2906 /* 2907 * ixgbe_enable_watchdog_timer - Enable and start the driver watchdog timer. 2908 */ 2909 void 2910 ixgbe_enable_watchdog_timer(ixgbe_t *ixgbe) 2911 { 2912 mutex_enter(&ixgbe->watchdog_lock); 2913 2914 if (!ixgbe->watchdog_enable) { 2915 ixgbe->watchdog_enable = B_TRUE; 2916 ixgbe->watchdog_start = B_TRUE; 2917 ixgbe_arm_watchdog_timer(ixgbe); 2918 } 2919 2920 mutex_exit(&ixgbe->watchdog_lock); 2921 } 2922 2923 /* 2924 * ixgbe_disable_watchdog_timer - Disable and stop the driver watchdog timer. 2925 */ 2926 void 2927 ixgbe_disable_watchdog_timer(ixgbe_t *ixgbe) 2928 { 2929 timeout_id_t tid; 2930 2931 mutex_enter(&ixgbe->watchdog_lock); 2932 2933 ixgbe->watchdog_enable = B_FALSE; 2934 ixgbe->watchdog_start = B_FALSE; 2935 tid = ixgbe->watchdog_tid; 2936 ixgbe->watchdog_tid = 0; 2937 2938 mutex_exit(&ixgbe->watchdog_lock); 2939 2940 if (tid != 0) 2941 (void) untimeout(tid); 2942 } 2943 2944 /* 2945 * ixgbe_start_watchdog_timer - Start the driver watchdog timer. 2946 */ 2947 void 2948 ixgbe_start_watchdog_timer(ixgbe_t *ixgbe) 2949 { 2950 mutex_enter(&ixgbe->watchdog_lock); 2951 2952 if (ixgbe->watchdog_enable) { 2953 if (!ixgbe->watchdog_start) { 2954 ixgbe->watchdog_start = B_TRUE; 2955 ixgbe_arm_watchdog_timer(ixgbe); 2956 } 2957 } 2958 2959 mutex_exit(&ixgbe->watchdog_lock); 2960 } 2961 2962 /* 2963 * ixgbe_restart_watchdog_timer - Restart the driver watchdog timer. 2964 */ 2965 static void 2966 ixgbe_restart_watchdog_timer(ixgbe_t *ixgbe) 2967 { 2968 mutex_enter(&ixgbe->watchdog_lock); 2969 2970 if (ixgbe->watchdog_start) 2971 ixgbe_arm_watchdog_timer(ixgbe); 2972 2973 mutex_exit(&ixgbe->watchdog_lock); 2974 } 2975 2976 /* 2977 * ixgbe_stop_watchdog_timer - Stop the driver watchdog timer. 2978 */ 2979 void 2980 ixgbe_stop_watchdog_timer(ixgbe_t *ixgbe) 2981 { 2982 timeout_id_t tid; 2983 2984 mutex_enter(&ixgbe->watchdog_lock); 2985 2986 ixgbe->watchdog_start = B_FALSE; 2987 tid = ixgbe->watchdog_tid; 2988 ixgbe->watchdog_tid = 0; 2989 2990 mutex_exit(&ixgbe->watchdog_lock); 2991 2992 if (tid != 0) 2993 (void) untimeout(tid); 2994 } 2995 2996 /* 2997 * ixgbe_disable_adapter_interrupts - Disable all adapter interrupts. 2998 */ 2999 static void 3000 ixgbe_disable_adapter_interrupts(ixgbe_t *ixgbe) 3001 { 3002 struct ixgbe_hw *hw = &ixgbe->hw; 3003 3004 /* 3005 * mask all interrupts off 3006 */ 3007 IXGBE_WRITE_REG(hw, IXGBE_EIMC, 0xffffffff); 3008 3009 /* 3010 * for MSI-X, also disable autoclear 3011 */ 3012 if (ixgbe->intr_type == DDI_INTR_TYPE_MSIX) { 3013 IXGBE_WRITE_REG(hw, IXGBE_EIAC, 0x0); 3014 } 3015 3016 IXGBE_WRITE_FLUSH(hw); 3017 } 3018 3019 /* 3020 * ixgbe_enable_adapter_interrupts - Enable all hardware interrupts. 3021 */ 3022 static void 3023 ixgbe_enable_adapter_interrupts(ixgbe_t *ixgbe) 3024 { 3025 struct ixgbe_hw *hw = &ixgbe->hw; 3026 uint32_t eiac, eiam; 3027 uint32_t gpie = IXGBE_READ_REG(hw, IXGBE_GPIE); 3028 3029 /* interrupt types to enable */ 3030 ixgbe->eims = IXGBE_EIMS_ENABLE_MASK; /* shared code default */ 3031 ixgbe->eims &= ~IXGBE_EIMS_TCP_TIMER; /* minus tcp timer */ 3032 ixgbe->eims |= ixgbe->capab->other_intr; /* "other" interrupt types */ 3033 3034 /* enable automask on "other" causes that this adapter can generate */ 3035 eiam = ixgbe->capab->other_intr; 3036 3037 /* 3038 * msi-x mode 3039 */ 3040 if (ixgbe->intr_type == DDI_INTR_TYPE_MSIX) { 3041 /* enable autoclear but not on bits 29:20 */ 3042 eiac = (ixgbe->eims & ~IXGBE_OTHER_INTR); 3043 3044 /* general purpose interrupt enable */ 3045 gpie |= (IXGBE_GPIE_MSIX_MODE 3046 | IXGBE_GPIE_PBA_SUPPORT 3047 | IXGBE_GPIE_OCD 3048 | IXGBE_GPIE_EIAME); 3049 /* 3050 * non-msi-x mode 3051 */ 3052 } else { 3053 3054 /* disable autoclear, leave gpie at default */ 3055 eiac = 0; 3056 3057 /* 3058 * General purpose interrupt enable. 3059 * For 82599, extended interrupt automask enable 3060 * only in MSI or MSI-X mode 3061 */ 3062 if ((hw->mac.type < ixgbe_mac_82599EB) || 3063 (ixgbe->intr_type == DDI_INTR_TYPE_MSI)) { 3064 gpie |= IXGBE_GPIE_EIAME; 3065 } 3066 } 3067 /* Enable specific interrupts for 82599 */ 3068 if (hw->mac.type == ixgbe_mac_82599EB) { 3069 gpie |= IXGBE_SDP2_GPIEN; /* pluggable optics intr */ 3070 gpie |= IXGBE_SDP1_GPIEN; /* LSC interrupt */ 3071 } 3072 3073 /* write to interrupt control registers */ 3074 IXGBE_WRITE_REG(hw, IXGBE_EIMS, ixgbe->eims); 3075 IXGBE_WRITE_REG(hw, IXGBE_EIAC, eiac); 3076 IXGBE_WRITE_REG(hw, IXGBE_EIAM, eiam); 3077 IXGBE_WRITE_REG(hw, IXGBE_GPIE, gpie); 3078 IXGBE_WRITE_FLUSH(hw); 3079 } 3080 3081 /* 3082 * ixgbe_loopback_ioctl - Loopback support. 3083 */ 3084 enum ioc_reply 3085 ixgbe_loopback_ioctl(ixgbe_t *ixgbe, struct iocblk *iocp, mblk_t *mp) 3086 { 3087 lb_info_sz_t *lbsp; 3088 lb_property_t *lbpp; 3089 uint32_t *lbmp; 3090 uint32_t size; 3091 uint32_t value; 3092 3093 if (mp->b_cont == NULL) 3094 return (IOC_INVAL); 3095 3096 switch (iocp->ioc_cmd) { 3097 default: 3098 return (IOC_INVAL); 3099 3100 case LB_GET_INFO_SIZE: 3101 size = sizeof (lb_info_sz_t); 3102 if (iocp->ioc_count != size) 3103 return (IOC_INVAL); 3104 3105 value = sizeof (lb_normal); 3106 value += sizeof (lb_mac); 3107 value += sizeof (lb_external); 3108 3109 lbsp = (lb_info_sz_t *)(uintptr_t)mp->b_cont->b_rptr; 3110 *lbsp = value; 3111 break; 3112 3113 case LB_GET_INFO: 3114 value = sizeof (lb_normal); 3115 value += sizeof (lb_mac); 3116 value += sizeof (lb_external); 3117 3118 size = value; 3119 if (iocp->ioc_count != size) 3120 return (IOC_INVAL); 3121 3122 value = 0; 3123 lbpp = (lb_property_t *)(uintptr_t)mp->b_cont->b_rptr; 3124 3125 lbpp[value++] = lb_normal; 3126 lbpp[value++] = lb_mac; 3127 lbpp[value++] = lb_external; 3128 break; 3129 3130 case LB_GET_MODE: 3131 size = sizeof (uint32_t); 3132 if (iocp->ioc_count != size) 3133 return (IOC_INVAL); 3134 3135 lbmp = (uint32_t *)(uintptr_t)mp->b_cont->b_rptr; 3136 *lbmp = ixgbe->loopback_mode; 3137 break; 3138 3139 case LB_SET_MODE: 3140 size = 0; 3141 if (iocp->ioc_count != sizeof (uint32_t)) 3142 return (IOC_INVAL); 3143 3144 lbmp = (uint32_t *)(uintptr_t)mp->b_cont->b_rptr; 3145 if (!ixgbe_set_loopback_mode(ixgbe, *lbmp)) 3146 return (IOC_INVAL); 3147 break; 3148 } 3149 3150 iocp->ioc_count = size; 3151 iocp->ioc_error = 0; 3152 3153 if (ixgbe_check_acc_handle(ixgbe->osdep.reg_handle) != DDI_FM_OK) { 3154 ddi_fm_service_impact(ixgbe->dip, DDI_SERVICE_DEGRADED); 3155 return (IOC_INVAL); 3156 } 3157 3158 return (IOC_REPLY); 3159 } 3160 3161 /* 3162 * ixgbe_set_loopback_mode - Setup loopback based on the loopback mode. 3163 */ 3164 static boolean_t 3165 ixgbe_set_loopback_mode(ixgbe_t *ixgbe, uint32_t mode) 3166 { 3167 if (mode == ixgbe->loopback_mode) 3168 return (B_TRUE); 3169 3170 ixgbe->loopback_mode = mode; 3171 3172 if (mode == IXGBE_LB_NONE) { 3173 /* 3174 * Reset the chip 3175 */ 3176 (void) ixgbe_reset(ixgbe); 3177 return (B_TRUE); 3178 } 3179 3180 mutex_enter(&ixgbe->gen_lock); 3181 3182 switch (mode) { 3183 default: 3184 mutex_exit(&ixgbe->gen_lock); 3185 return (B_FALSE); 3186 3187 case IXGBE_LB_EXTERNAL: 3188 break; 3189 3190 case IXGBE_LB_INTERNAL_MAC: 3191 ixgbe_set_internal_mac_loopback(ixgbe); 3192 break; 3193 } 3194 3195 mutex_exit(&ixgbe->gen_lock); 3196 3197 return (B_TRUE); 3198 } 3199 3200 /* 3201 * ixgbe_set_internal_mac_loopback - Set the internal MAC loopback mode. 3202 */ 3203 static void 3204 ixgbe_set_internal_mac_loopback(ixgbe_t *ixgbe) 3205 { 3206 struct ixgbe_hw *hw; 3207 uint32_t reg; 3208 uint8_t atlas; 3209 3210 hw = &ixgbe->hw; 3211 3212 /* 3213 * Setup MAC loopback 3214 */ 3215 reg = IXGBE_READ_REG(&ixgbe->hw, IXGBE_HLREG0); 3216 reg |= IXGBE_HLREG0_LPBK; 3217 IXGBE_WRITE_REG(&ixgbe->hw, IXGBE_HLREG0, reg); 3218 3219 reg = IXGBE_READ_REG(&ixgbe->hw, IXGBE_AUTOC); 3220 reg &= ~IXGBE_AUTOC_LMS_MASK; 3221 IXGBE_WRITE_REG(&ixgbe->hw, IXGBE_AUTOC, reg); 3222 3223 /* 3224 * Disable Atlas Tx lanes to keep packets in loopback and not on wire 3225 */ 3226 if (hw->mac.type == ixgbe_mac_82598EB) { 3227 (void) ixgbe_read_analog_reg8(&ixgbe->hw, IXGBE_ATLAS_PDN_LPBK, 3228 &atlas); 3229 atlas |= IXGBE_ATLAS_PDN_TX_REG_EN; 3230 (void) ixgbe_write_analog_reg8(&ixgbe->hw, IXGBE_ATLAS_PDN_LPBK, 3231 atlas); 3232 3233 (void) ixgbe_read_analog_reg8(&ixgbe->hw, IXGBE_ATLAS_PDN_10G, 3234 &atlas); 3235 atlas |= IXGBE_ATLAS_PDN_TX_10G_QL_ALL; 3236 (void) ixgbe_write_analog_reg8(&ixgbe->hw, IXGBE_ATLAS_PDN_10G, 3237 atlas); 3238 3239 (void) ixgbe_read_analog_reg8(&ixgbe->hw, IXGBE_ATLAS_PDN_1G, 3240 &atlas); 3241 atlas |= IXGBE_ATLAS_PDN_TX_1G_QL_ALL; 3242 (void) ixgbe_write_analog_reg8(&ixgbe->hw, IXGBE_ATLAS_PDN_1G, 3243 atlas); 3244 3245 (void) ixgbe_read_analog_reg8(&ixgbe->hw, IXGBE_ATLAS_PDN_AN, 3246 &atlas); 3247 atlas |= IXGBE_ATLAS_PDN_TX_AN_QL_ALL; 3248 (void) ixgbe_write_analog_reg8(&ixgbe->hw, IXGBE_ATLAS_PDN_AN, 3249 atlas); 3250 } 3251 } 3252 3253 #pragma inline(ixgbe_intr_rx_work) 3254 /* 3255 * ixgbe_intr_rx_work - RX processing of ISR. 3256 */ 3257 static void 3258 ixgbe_intr_rx_work(ixgbe_rx_ring_t *rx_ring) 3259 { 3260 mblk_t *mp; 3261 3262 mutex_enter(&rx_ring->rx_lock); 3263 3264 mp = ixgbe_ring_rx(rx_ring, IXGBE_POLL_NULL); 3265 mutex_exit(&rx_ring->rx_lock); 3266 3267 if (mp != NULL) 3268 mac_rx_ring(rx_ring->ixgbe->mac_hdl, rx_ring->ring_handle, mp, 3269 rx_ring->ring_gen_num); 3270 } 3271 3272 #pragma inline(ixgbe_intr_tx_work) 3273 /* 3274 * ixgbe_intr_tx_work - TX processing of ISR. 3275 */ 3276 static void 3277 ixgbe_intr_tx_work(ixgbe_tx_ring_t *tx_ring) 3278 { 3279 ixgbe_t *ixgbe = tx_ring->ixgbe; 3280 3281 /* 3282 * Recycle the tx descriptors 3283 */ 3284 tx_ring->tx_recycle(tx_ring); 3285 3286 /* 3287 * Schedule the re-transmit 3288 */ 3289 if (tx_ring->reschedule && 3290 (tx_ring->tbd_free >= ixgbe->tx_resched_thresh)) { 3291 tx_ring->reschedule = B_FALSE; 3292 mac_tx_ring_update(tx_ring->ixgbe->mac_hdl, 3293 tx_ring->ring_handle); 3294 IXGBE_DEBUG_STAT(tx_ring->stat_reschedule); 3295 } 3296 } 3297 3298 #pragma inline(ixgbe_intr_other_work) 3299 /* 3300 * ixgbe_intr_other_work - Process interrupt types other than tx/rx 3301 */ 3302 static void 3303 ixgbe_intr_other_work(ixgbe_t *ixgbe, uint32_t eicr) 3304 { 3305 struct ixgbe_hw *hw = &ixgbe->hw; 3306 3307 ASSERT(mutex_owned(&ixgbe->gen_lock)); 3308 3309 /* 3310 * handle link status change 3311 */ 3312 if (eicr & IXGBE_EICR_LSC) { 3313 ixgbe_driver_link_check(ixgbe); 3314 } 3315 3316 /* 3317 * check for fan failure on adapters with fans 3318 */ 3319 if ((ixgbe->capab->flags & IXGBE_FLAG_FAN_FAIL_CAPABLE) && 3320 (eicr & IXGBE_EICR_GPI_SDP1)) { 3321 if (hw->mac.type < ixgbe_mac_82599EB) { 3322 ixgbe_log(ixgbe, 3323 "Fan has stopped, replace the adapter\n"); 3324 3325 /* re-enable the interrupt, which was automasked */ 3326 ixgbe->eims |= IXGBE_EICR_GPI_SDP1; 3327 } 3328 } 3329 3330 /* 3331 * Do SFP check for 82599 3332 */ 3333 if (hw->mac.type == ixgbe_mac_82599EB) { 3334 if ((ddi_taskq_dispatch(ixgbe->sfp_taskq, 3335 ixgbe_sfp_check, (void *)ixgbe, 3336 DDI_NOSLEEP)) != DDI_SUCCESS) { 3337 ixgbe_log(ixgbe, "No memory available to dispatch " 3338 "taskq for SFP check"); 3339 } 3340 3341 /* 3342 * We need to fully re-check the link later. 3343 */ 3344 ixgbe->link_check_complete = B_FALSE; 3345 ixgbe->link_check_hrtime = gethrtime() + 3346 (IXGBE_LINK_UP_TIME * 100000000ULL); 3347 } 3348 } 3349 3350 /* 3351 * ixgbe_intr_legacy - Interrupt handler for legacy interrupts. 3352 */ 3353 static uint_t 3354 ixgbe_intr_legacy(void *arg1, void *arg2) 3355 { 3356 ixgbe_t *ixgbe = (ixgbe_t *)arg1; 3357 struct ixgbe_hw *hw = &ixgbe->hw; 3358 ixgbe_tx_ring_t *tx_ring; 3359 ixgbe_rx_ring_t *rx_ring; 3360 uint32_t eicr; 3361 mblk_t *mp; 3362 boolean_t tx_reschedule; 3363 uint_t result; 3364 3365 _NOTE(ARGUNUSED(arg2)); 3366 3367 mutex_enter(&ixgbe->gen_lock); 3368 if (ixgbe->ixgbe_state & IXGBE_SUSPENDED) { 3369 mutex_exit(&ixgbe->gen_lock); 3370 return (DDI_INTR_UNCLAIMED); 3371 } 3372 3373 mp = NULL; 3374 tx_reschedule = B_FALSE; 3375 3376 /* 3377 * Any bit set in eicr: claim this interrupt 3378 */ 3379 eicr = IXGBE_READ_REG(hw, IXGBE_EICR); 3380 3381 if (ixgbe_check_acc_handle(ixgbe->osdep.reg_handle) != DDI_FM_OK) { 3382 ddi_fm_service_impact(ixgbe->dip, DDI_SERVICE_DEGRADED); 3383 atomic_or_32(&ixgbe->ixgbe_state, IXGBE_ERROR); 3384 return (DDI_INTR_CLAIMED); 3385 } 3386 3387 if (eicr) { 3388 /* 3389 * For legacy interrupt, we have only one interrupt, 3390 * so we have only one rx ring and one tx ring enabled. 3391 */ 3392 ASSERT(ixgbe->num_rx_rings == 1); 3393 ASSERT(ixgbe->num_tx_rings == 1); 3394 3395 /* 3396 * For legacy interrupt, rx rings[0] will use RTxQ[0]. 3397 */ 3398 if (eicr & 0x1) { 3399 ixgbe->eimc |= IXGBE_EICR_RTX_QUEUE; 3400 IXGBE_WRITE_REG(hw, IXGBE_EIMC, ixgbe->eimc); 3401 ixgbe->eims |= IXGBE_EICR_RTX_QUEUE; 3402 /* 3403 * Clean the rx descriptors 3404 */ 3405 rx_ring = &ixgbe->rx_rings[0]; 3406 mp = ixgbe_ring_rx(rx_ring, IXGBE_POLL_NULL); 3407 } 3408 3409 /* 3410 * For legacy interrupt, tx rings[0] will use RTxQ[1]. 3411 */ 3412 if (eicr & 0x2) { 3413 /* 3414 * Recycle the tx descriptors 3415 */ 3416 tx_ring = &ixgbe->tx_rings[0]; 3417 tx_ring->tx_recycle(tx_ring); 3418 3419 /* 3420 * Schedule the re-transmit 3421 */ 3422 tx_reschedule = (tx_ring->reschedule && 3423 (tx_ring->tbd_free >= ixgbe->tx_resched_thresh)); 3424 } 3425 3426 /* any interrupt type other than tx/rx */ 3427 if (eicr & ixgbe->capab->other_intr) { 3428 if (hw->mac.type < ixgbe_mac_82599EB) { 3429 ixgbe->eims &= ~(eicr & IXGBE_OTHER_INTR); 3430 } 3431 if (hw->mac.type == ixgbe_mac_82599EB) { 3432 ixgbe->eimc = IXGBE_82599_OTHER_INTR; 3433 IXGBE_WRITE_REG(hw, IXGBE_EIMC, ixgbe->eimc); 3434 } 3435 ixgbe_intr_other_work(ixgbe, eicr); 3436 ixgbe->eims &= ~(eicr & IXGBE_OTHER_INTR); 3437 } 3438 3439 mutex_exit(&ixgbe->gen_lock); 3440 3441 result = DDI_INTR_CLAIMED; 3442 } else { 3443 mutex_exit(&ixgbe->gen_lock); 3444 3445 /* 3446 * No interrupt cause bits set: don't claim this interrupt. 3447 */ 3448 result = DDI_INTR_UNCLAIMED; 3449 } 3450 3451 /* re-enable the interrupts which were automasked */ 3452 IXGBE_WRITE_REG(hw, IXGBE_EIMS, ixgbe->eims); 3453 3454 /* 3455 * Do the following work outside of the gen_lock 3456 */ 3457 if (mp != NULL) { 3458 mac_rx_ring(rx_ring->ixgbe->mac_hdl, rx_ring->ring_handle, mp, 3459 rx_ring->ring_gen_num); 3460 } 3461 3462 if (tx_reschedule) { 3463 tx_ring->reschedule = B_FALSE; 3464 mac_tx_ring_update(ixgbe->mac_hdl, tx_ring->ring_handle); 3465 IXGBE_DEBUG_STAT(tx_ring->stat_reschedule); 3466 } 3467 3468 return (result); 3469 } 3470 3471 /* 3472 * ixgbe_intr_msi - Interrupt handler for MSI. 3473 */ 3474 static uint_t 3475 ixgbe_intr_msi(void *arg1, void *arg2) 3476 { 3477 ixgbe_t *ixgbe = (ixgbe_t *)arg1; 3478 struct ixgbe_hw *hw = &ixgbe->hw; 3479 uint32_t eicr; 3480 3481 _NOTE(ARGUNUSED(arg2)); 3482 3483 eicr = IXGBE_READ_REG(hw, IXGBE_EICR); 3484 3485 if (ixgbe_check_acc_handle(ixgbe->osdep.reg_handle) != DDI_FM_OK) { 3486 ddi_fm_service_impact(ixgbe->dip, DDI_SERVICE_DEGRADED); 3487 atomic_or_32(&ixgbe->ixgbe_state, IXGBE_ERROR); 3488 return (DDI_INTR_CLAIMED); 3489 } 3490 3491 /* 3492 * For MSI interrupt, we have only one vector, 3493 * so we have only one rx ring and one tx ring enabled. 3494 */ 3495 ASSERT(ixgbe->num_rx_rings == 1); 3496 ASSERT(ixgbe->num_tx_rings == 1); 3497 3498 /* 3499 * For MSI interrupt, rx rings[0] will use RTxQ[0]. 3500 */ 3501 if (eicr & 0x1) { 3502 ixgbe_intr_rx_work(&ixgbe->rx_rings[0]); 3503 } 3504 3505 /* 3506 * For MSI interrupt, tx rings[0] will use RTxQ[1]. 3507 */ 3508 if (eicr & 0x2) { 3509 ixgbe_intr_tx_work(&ixgbe->tx_rings[0]); 3510 } 3511 3512 /* any interrupt type other than tx/rx */ 3513 if (eicr & ixgbe->capab->other_intr) { 3514 mutex_enter(&ixgbe->gen_lock); 3515 if (hw->mac.type < ixgbe_mac_82599EB) { 3516 ixgbe->eims &= ~(eicr & IXGBE_OTHER_INTR); 3517 } 3518 if (hw->mac.type == ixgbe_mac_82599EB) { 3519 ixgbe->eimc = IXGBE_82599_OTHER_INTR; 3520 IXGBE_WRITE_REG(hw, IXGBE_EIMC, ixgbe->eimc); 3521 } 3522 ixgbe_intr_other_work(ixgbe, eicr); 3523 ixgbe->eims &= ~(eicr & IXGBE_OTHER_INTR); 3524 mutex_exit(&ixgbe->gen_lock); 3525 } 3526 3527 /* re-enable the interrupts which were automasked */ 3528 IXGBE_WRITE_REG(hw, IXGBE_EIMS, ixgbe->eims); 3529 3530 return (DDI_INTR_CLAIMED); 3531 } 3532 3533 /* 3534 * ixgbe_intr_msix - Interrupt handler for MSI-X. 3535 */ 3536 static uint_t 3537 ixgbe_intr_msix(void *arg1, void *arg2) 3538 { 3539 ixgbe_intr_vector_t *vect = (ixgbe_intr_vector_t *)arg1; 3540 ixgbe_t *ixgbe = vect->ixgbe; 3541 struct ixgbe_hw *hw = &ixgbe->hw; 3542 uint32_t eicr; 3543 int r_idx = 0; 3544 3545 _NOTE(ARGUNUSED(arg2)); 3546 3547 /* 3548 * Clean each rx ring that has its bit set in the map 3549 */ 3550 r_idx = bt_getlowbit(vect->rx_map, 0, (ixgbe->num_rx_rings - 1)); 3551 while (r_idx >= 0) { 3552 ixgbe_intr_rx_work(&ixgbe->rx_rings[r_idx]); 3553 r_idx = bt_getlowbit(vect->rx_map, (r_idx + 1), 3554 (ixgbe->num_rx_rings - 1)); 3555 } 3556 3557 /* 3558 * Clean each tx ring that has its bit set in the map 3559 */ 3560 r_idx = bt_getlowbit(vect->tx_map, 0, (ixgbe->num_tx_rings - 1)); 3561 while (r_idx >= 0) { 3562 ixgbe_intr_tx_work(&ixgbe->tx_rings[r_idx]); 3563 r_idx = bt_getlowbit(vect->tx_map, (r_idx + 1), 3564 (ixgbe->num_tx_rings - 1)); 3565 } 3566 3567 3568 /* 3569 * Clean other interrupt (link change) that has its bit set in the map 3570 */ 3571 if (BT_TEST(vect->other_map, 0) == 1) { 3572 eicr = IXGBE_READ_REG(hw, IXGBE_EICR); 3573 3574 if (ixgbe_check_acc_handle(ixgbe->osdep.reg_handle) != 3575 DDI_FM_OK) { 3576 ddi_fm_service_impact(ixgbe->dip, 3577 DDI_SERVICE_DEGRADED); 3578 atomic_or_32(&ixgbe->ixgbe_state, IXGBE_ERROR); 3579 return (DDI_INTR_CLAIMED); 3580 } 3581 3582 /* 3583 * Need check cause bits and only other causes will 3584 * be processed 3585 */ 3586 /* any interrupt type other than tx/rx */ 3587 if (eicr & ixgbe->capab->other_intr) { 3588 if (hw->mac.type < ixgbe_mac_82599EB) { 3589 mutex_enter(&ixgbe->gen_lock); 3590 ixgbe->eims &= ~(eicr & IXGBE_OTHER_INTR); 3591 ixgbe_intr_other_work(ixgbe, eicr); 3592 mutex_exit(&ixgbe->gen_lock); 3593 } else { 3594 if (hw->mac.type == ixgbe_mac_82599EB) { 3595 mutex_enter(&ixgbe->gen_lock); 3596 ixgbe->eims |= IXGBE_EICR_RTX_QUEUE; 3597 ixgbe_intr_other_work(ixgbe, eicr); 3598 mutex_exit(&ixgbe->gen_lock); 3599 } 3600 } 3601 } 3602 3603 /* re-enable the interrupts which were automasked */ 3604 IXGBE_WRITE_REG(hw, IXGBE_EIMS, ixgbe->eims); 3605 } 3606 3607 return (DDI_INTR_CLAIMED); 3608 } 3609 3610 /* 3611 * ixgbe_alloc_intrs - Allocate interrupts for the driver. 3612 * 3613 * Normal sequence is to try MSI-X; if not sucessful, try MSI; 3614 * if not successful, try Legacy. 3615 * ixgbe->intr_force can be used to force sequence to start with 3616 * any of the 3 types. 3617 * If MSI-X is not used, number of tx/rx rings is forced to 1. 3618 */ 3619 static int 3620 ixgbe_alloc_intrs(ixgbe_t *ixgbe) 3621 { 3622 dev_info_t *devinfo; 3623 int intr_types; 3624 int rc; 3625 3626 devinfo = ixgbe->dip; 3627 3628 /* 3629 * Get supported interrupt types 3630 */ 3631 rc = ddi_intr_get_supported_types(devinfo, &intr_types); 3632 3633 if (rc != DDI_SUCCESS) { 3634 ixgbe_log(ixgbe, 3635 "Get supported interrupt types failed: %d", rc); 3636 return (IXGBE_FAILURE); 3637 } 3638 IXGBE_DEBUGLOG_1(ixgbe, "Supported interrupt types: %x", intr_types); 3639 3640 ixgbe->intr_type = 0; 3641 3642 /* 3643 * Install MSI-X interrupts 3644 */ 3645 if ((intr_types & DDI_INTR_TYPE_MSIX) && 3646 (ixgbe->intr_force <= IXGBE_INTR_MSIX)) { 3647 rc = ixgbe_alloc_intr_handles(ixgbe, DDI_INTR_TYPE_MSIX); 3648 if (rc == IXGBE_SUCCESS) 3649 return (IXGBE_SUCCESS); 3650 3651 ixgbe_log(ixgbe, 3652 "Allocate MSI-X failed, trying MSI interrupts..."); 3653 } 3654 3655 /* 3656 * MSI-X not used, force rings and groups to 1 3657 */ 3658 ixgbe->num_rx_rings = 1; 3659 ixgbe->num_rx_groups = 1; 3660 ixgbe->num_tx_rings = 1; 3661 ixgbe_log(ixgbe, 3662 "MSI-X not used, force rings and groups number to 1"); 3663 3664 /* 3665 * Install MSI interrupts 3666 */ 3667 if ((intr_types & DDI_INTR_TYPE_MSI) && 3668 (ixgbe->intr_force <= IXGBE_INTR_MSI)) { 3669 rc = ixgbe_alloc_intr_handles(ixgbe, DDI_INTR_TYPE_MSI); 3670 if (rc == IXGBE_SUCCESS) 3671 return (IXGBE_SUCCESS); 3672 3673 ixgbe_log(ixgbe, 3674 "Allocate MSI failed, trying Legacy interrupts..."); 3675 } 3676 3677 /* 3678 * Install legacy interrupts 3679 */ 3680 if (intr_types & DDI_INTR_TYPE_FIXED) { 3681 rc = ixgbe_alloc_intr_handles(ixgbe, DDI_INTR_TYPE_FIXED); 3682 if (rc == IXGBE_SUCCESS) 3683 return (IXGBE_SUCCESS); 3684 3685 ixgbe_log(ixgbe, 3686 "Allocate Legacy interrupts failed"); 3687 } 3688 3689 /* 3690 * If none of the 3 types succeeded, return failure 3691 */ 3692 return (IXGBE_FAILURE); 3693 } 3694 3695 /* 3696 * ixgbe_alloc_intr_handles - Allocate interrupt handles. 3697 * 3698 * For legacy and MSI, only 1 handle is needed. For MSI-X, 3699 * if fewer than 2 handles are available, return failure. 3700 * Upon success, this maps the vectors to rx and tx rings for 3701 * interrupts. 3702 */ 3703 static int 3704 ixgbe_alloc_intr_handles(ixgbe_t *ixgbe, int intr_type) 3705 { 3706 dev_info_t *devinfo; 3707 int request, count, avail, actual; 3708 int minimum; 3709 int rc; 3710 3711 devinfo = ixgbe->dip; 3712 3713 switch (intr_type) { 3714 case DDI_INTR_TYPE_FIXED: 3715 request = 1; /* Request 1 legacy interrupt handle */ 3716 minimum = 1; 3717 IXGBE_DEBUGLOG_0(ixgbe, "interrupt type: legacy"); 3718 break; 3719 3720 case DDI_INTR_TYPE_MSI: 3721 request = 1; /* Request 1 MSI interrupt handle */ 3722 minimum = 1; 3723 IXGBE_DEBUGLOG_0(ixgbe, "interrupt type: MSI"); 3724 break; 3725 3726 case DDI_INTR_TYPE_MSIX: 3727 /* 3728 * Best number of vectors for the adapter is 3729 * # rx rings + # tx rings. 3730 */ 3731 request = ixgbe->num_rx_rings + ixgbe->num_tx_rings; 3732 if (request > ixgbe->capab->max_ring_vect) 3733 request = ixgbe->capab->max_ring_vect; 3734 minimum = 2; 3735 IXGBE_DEBUGLOG_0(ixgbe, "interrupt type: MSI-X"); 3736 break; 3737 3738 default: 3739 ixgbe_log(ixgbe, 3740 "invalid call to ixgbe_alloc_intr_handles(): %d\n", 3741 intr_type); 3742 return (IXGBE_FAILURE); 3743 } 3744 IXGBE_DEBUGLOG_2(ixgbe, "interrupt handles requested: %d minimum: %d", 3745 request, minimum); 3746 3747 /* 3748 * Get number of supported interrupts 3749 */ 3750 rc = ddi_intr_get_nintrs(devinfo, intr_type, &count); 3751 if ((rc != DDI_SUCCESS) || (count < minimum)) { 3752 ixgbe_log(ixgbe, 3753 "Get interrupt number failed. Return: %d, count: %d", 3754 rc, count); 3755 return (IXGBE_FAILURE); 3756 } 3757 IXGBE_DEBUGLOG_1(ixgbe, "interrupts supported: %d", count); 3758 3759 /* 3760 * Get number of available interrupts 3761 */ 3762 rc = ddi_intr_get_navail(devinfo, intr_type, &avail); 3763 if ((rc != DDI_SUCCESS) || (avail < minimum)) { 3764 ixgbe_log(ixgbe, 3765 "Get interrupt available number failed. " 3766 "Return: %d, available: %d", rc, avail); 3767 return (IXGBE_FAILURE); 3768 } 3769 IXGBE_DEBUGLOG_1(ixgbe, "interrupts available: %d", avail); 3770 3771 if (avail < request) { 3772 ixgbe_log(ixgbe, "Request %d handles, %d available", 3773 request, avail); 3774 request = avail; 3775 } 3776 3777 actual = 0; 3778 ixgbe->intr_cnt = 0; 3779 3780 /* 3781 * Allocate an array of interrupt handles 3782 */ 3783 ixgbe->intr_size = request * sizeof (ddi_intr_handle_t); 3784 ixgbe->htable = kmem_alloc(ixgbe->intr_size, KM_SLEEP); 3785 3786 rc = ddi_intr_alloc(devinfo, ixgbe->htable, intr_type, 0, 3787 request, &actual, DDI_INTR_ALLOC_NORMAL); 3788 if (rc != DDI_SUCCESS) { 3789 ixgbe_log(ixgbe, "Allocate interrupts failed. " 3790 "return: %d, request: %d, actual: %d", 3791 rc, request, actual); 3792 goto alloc_handle_fail; 3793 } 3794 IXGBE_DEBUGLOG_1(ixgbe, "interrupts actually allocated: %d", actual); 3795 3796 ixgbe->intr_cnt = actual; 3797 3798 /* 3799 * Now we know the actual number of vectors. Here we map the vector 3800 * to other, rx rings and tx ring. 3801 */ 3802 if (actual < minimum) { 3803 ixgbe_log(ixgbe, "Insufficient interrupt handles available: %d", 3804 actual); 3805 goto alloc_handle_fail; 3806 } 3807 3808 /* 3809 * Get priority for first vector, assume remaining are all the same 3810 */ 3811 rc = ddi_intr_get_pri(ixgbe->htable[0], &ixgbe->intr_pri); 3812 if (rc != DDI_SUCCESS) { 3813 ixgbe_log(ixgbe, 3814 "Get interrupt priority failed: %d", rc); 3815 goto alloc_handle_fail; 3816 } 3817 3818 rc = ddi_intr_get_cap(ixgbe->htable[0], &ixgbe->intr_cap); 3819 if (rc != DDI_SUCCESS) { 3820 ixgbe_log(ixgbe, 3821 "Get interrupt cap failed: %d", rc); 3822 goto alloc_handle_fail; 3823 } 3824 3825 ixgbe->intr_type = intr_type; 3826 3827 return (IXGBE_SUCCESS); 3828 3829 alloc_handle_fail: 3830 ixgbe_rem_intrs(ixgbe); 3831 3832 return (IXGBE_FAILURE); 3833 } 3834 3835 /* 3836 * ixgbe_add_intr_handlers - Add interrupt handlers based on the interrupt type. 3837 * 3838 * Before adding the interrupt handlers, the interrupt vectors have 3839 * been allocated, and the rx/tx rings have also been allocated. 3840 */ 3841 static int 3842 ixgbe_add_intr_handlers(ixgbe_t *ixgbe) 3843 { 3844 int vector = 0; 3845 int rc; 3846 3847 switch (ixgbe->intr_type) { 3848 case DDI_INTR_TYPE_MSIX: 3849 /* 3850 * Add interrupt handler for all vectors 3851 */ 3852 for (vector = 0; vector < ixgbe->intr_cnt; vector++) { 3853 /* 3854 * install pointer to vect_map[vector] 3855 */ 3856 rc = ddi_intr_add_handler(ixgbe->htable[vector], 3857 (ddi_intr_handler_t *)ixgbe_intr_msix, 3858 (void *)&ixgbe->vect_map[vector], NULL); 3859 3860 if (rc != DDI_SUCCESS) { 3861 ixgbe_log(ixgbe, 3862 "Add rx interrupt handler failed. " 3863 "return: %d, vector: %d", rc, vector); 3864 for (vector--; vector >= 0; vector--) { 3865 (void) ddi_intr_remove_handler( 3866 ixgbe->htable[vector]); 3867 } 3868 return (IXGBE_FAILURE); 3869 } 3870 } 3871 3872 break; 3873 3874 case DDI_INTR_TYPE_MSI: 3875 /* 3876 * Add interrupt handlers for the only vector 3877 */ 3878 rc = ddi_intr_add_handler(ixgbe->htable[vector], 3879 (ddi_intr_handler_t *)ixgbe_intr_msi, 3880 (void *)ixgbe, NULL); 3881 3882 if (rc != DDI_SUCCESS) { 3883 ixgbe_log(ixgbe, 3884 "Add MSI interrupt handler failed: %d", rc); 3885 return (IXGBE_FAILURE); 3886 } 3887 3888 break; 3889 3890 case DDI_INTR_TYPE_FIXED: 3891 /* 3892 * Add interrupt handlers for the only vector 3893 */ 3894 rc = ddi_intr_add_handler(ixgbe->htable[vector], 3895 (ddi_intr_handler_t *)ixgbe_intr_legacy, 3896 (void *)ixgbe, NULL); 3897 3898 if (rc != DDI_SUCCESS) { 3899 ixgbe_log(ixgbe, 3900 "Add legacy interrupt handler failed: %d", rc); 3901 return (IXGBE_FAILURE); 3902 } 3903 3904 break; 3905 3906 default: 3907 return (IXGBE_FAILURE); 3908 } 3909 3910 return (IXGBE_SUCCESS); 3911 } 3912 3913 #pragma inline(ixgbe_map_rxring_to_vector) 3914 /* 3915 * ixgbe_map_rxring_to_vector - Map given rx ring to given interrupt vector. 3916 */ 3917 static void 3918 ixgbe_map_rxring_to_vector(ixgbe_t *ixgbe, int r_idx, int v_idx) 3919 { 3920 /* 3921 * Set bit in map 3922 */ 3923 BT_SET(ixgbe->vect_map[v_idx].rx_map, r_idx); 3924 3925 /* 3926 * Count bits set 3927 */ 3928 ixgbe->vect_map[v_idx].rxr_cnt++; 3929 3930 /* 3931 * Remember bit position 3932 */ 3933 ixgbe->rx_rings[r_idx].intr_vector = v_idx; 3934 ixgbe->rx_rings[r_idx].vect_bit = 1 << v_idx; 3935 } 3936 3937 #pragma inline(ixgbe_map_txring_to_vector) 3938 /* 3939 * ixgbe_map_txring_to_vector - Map given tx ring to given interrupt vector. 3940 */ 3941 static void 3942 ixgbe_map_txring_to_vector(ixgbe_t *ixgbe, int t_idx, int v_idx) 3943 { 3944 /* 3945 * Set bit in map 3946 */ 3947 BT_SET(ixgbe->vect_map[v_idx].tx_map, t_idx); 3948 3949 /* 3950 * Count bits set 3951 */ 3952 ixgbe->vect_map[v_idx].txr_cnt++; 3953 3954 /* 3955 * Remember bit position 3956 */ 3957 ixgbe->tx_rings[t_idx].intr_vector = v_idx; 3958 ixgbe->tx_rings[t_idx].vect_bit = 1 << v_idx; 3959 } 3960 3961 /* 3962 * ixgbe_setup_ivar - Set the given entry in the given interrupt vector 3963 * allocation register (IVAR). 3964 * cause: 3965 * -1 : other cause 3966 * 0 : rx 3967 * 1 : tx 3968 */ 3969 static void 3970 ixgbe_setup_ivar(ixgbe_t *ixgbe, uint16_t intr_alloc_entry, uint8_t msix_vector, 3971 int8_t cause) 3972 { 3973 struct ixgbe_hw *hw = &ixgbe->hw; 3974 u32 ivar, index; 3975 3976 switch (hw->mac.type) { 3977 case ixgbe_mac_82598EB: 3978 msix_vector |= IXGBE_IVAR_ALLOC_VAL; 3979 if (cause == -1) { 3980 cause = 0; 3981 } 3982 index = (((cause * 64) + intr_alloc_entry) >> 2) & 0x1F; 3983 ivar = IXGBE_READ_REG(hw, IXGBE_IVAR(index)); 3984 ivar &= ~(0xFF << (8 * (intr_alloc_entry & 0x3))); 3985 ivar |= (msix_vector << (8 * (intr_alloc_entry & 0x3))); 3986 IXGBE_WRITE_REG(hw, IXGBE_IVAR(index), ivar); 3987 break; 3988 case ixgbe_mac_82599EB: 3989 if (cause == -1) { 3990 /* other causes */ 3991 msix_vector |= IXGBE_IVAR_ALLOC_VAL; 3992 index = (intr_alloc_entry & 1) * 8; 3993 ivar = IXGBE_READ_REG(hw, IXGBE_IVAR_MISC); 3994 ivar &= ~(0xFF << index); 3995 ivar |= (msix_vector << index); 3996 IXGBE_WRITE_REG(hw, IXGBE_IVAR_MISC, ivar); 3997 } else { 3998 /* tx or rx causes */ 3999 msix_vector |= IXGBE_IVAR_ALLOC_VAL; 4000 index = ((16 * (intr_alloc_entry & 1)) + (8 * cause)); 4001 ivar = IXGBE_READ_REG(hw, 4002 IXGBE_IVAR(intr_alloc_entry >> 1)); 4003 ivar &= ~(0xFF << index); 4004 ivar |= (msix_vector << index); 4005 IXGBE_WRITE_REG(hw, IXGBE_IVAR(intr_alloc_entry >> 1), 4006 ivar); 4007 } 4008 break; 4009 default: 4010 break; 4011 } 4012 } 4013 4014 /* 4015 * ixgbe_enable_ivar - Enable the given entry by setting the VAL bit of 4016 * given interrupt vector allocation register (IVAR). 4017 * cause: 4018 * -1 : other cause 4019 * 0 : rx 4020 * 1 : tx 4021 */ 4022 static void 4023 ixgbe_enable_ivar(ixgbe_t *ixgbe, uint16_t intr_alloc_entry, int8_t cause) 4024 { 4025 struct ixgbe_hw *hw = &ixgbe->hw; 4026 u32 ivar, index; 4027 4028 switch (hw->mac.type) { 4029 case ixgbe_mac_82598EB: 4030 if (cause == -1) { 4031 cause = 0; 4032 } 4033 index = (((cause * 64) + intr_alloc_entry) >> 2) & 0x1F; 4034 ivar = IXGBE_READ_REG(hw, IXGBE_IVAR(index)); 4035 ivar |= (IXGBE_IVAR_ALLOC_VAL << (8 * 4036 (intr_alloc_entry & 0x3))); 4037 IXGBE_WRITE_REG(hw, IXGBE_IVAR(index), ivar); 4038 break; 4039 case ixgbe_mac_82599EB: 4040 if (cause == -1) { 4041 /* other causes */ 4042 index = (intr_alloc_entry & 1) * 8; 4043 ivar = IXGBE_READ_REG(hw, IXGBE_IVAR_MISC); 4044 ivar |= (IXGBE_IVAR_ALLOC_VAL << index); 4045 IXGBE_WRITE_REG(hw, IXGBE_IVAR_MISC, ivar); 4046 } else { 4047 /* tx or rx causes */ 4048 index = ((16 * (intr_alloc_entry & 1)) + (8 * cause)); 4049 ivar = IXGBE_READ_REG(hw, 4050 IXGBE_IVAR(intr_alloc_entry >> 1)); 4051 ivar |= (IXGBE_IVAR_ALLOC_VAL << index); 4052 IXGBE_WRITE_REG(hw, IXGBE_IVAR(intr_alloc_entry >> 1), 4053 ivar); 4054 } 4055 break; 4056 default: 4057 break; 4058 } 4059 } 4060 4061 /* 4062 * ixgbe_disable_ivar - Disble the given entry by clearing the VAL bit of 4063 * given interrupt vector allocation register (IVAR). 4064 * cause: 4065 * -1 : other cause 4066 * 0 : rx 4067 * 1 : tx 4068 */ 4069 static void 4070 ixgbe_disable_ivar(ixgbe_t *ixgbe, uint16_t intr_alloc_entry, int8_t cause) 4071 { 4072 struct ixgbe_hw *hw = &ixgbe->hw; 4073 u32 ivar, index; 4074 4075 switch (hw->mac.type) { 4076 case ixgbe_mac_82598EB: 4077 if (cause == -1) { 4078 cause = 0; 4079 } 4080 index = (((cause * 64) + intr_alloc_entry) >> 2) & 0x1F; 4081 ivar = IXGBE_READ_REG(hw, IXGBE_IVAR(index)); 4082 ivar &= ~(IXGBE_IVAR_ALLOC_VAL<< (8 * 4083 (intr_alloc_entry & 0x3))); 4084 IXGBE_WRITE_REG(hw, IXGBE_IVAR(index), ivar); 4085 break; 4086 case ixgbe_mac_82599EB: 4087 if (cause == -1) { 4088 /* other causes */ 4089 index = (intr_alloc_entry & 1) * 8; 4090 ivar = IXGBE_READ_REG(hw, IXGBE_IVAR_MISC); 4091 ivar &= ~(IXGBE_IVAR_ALLOC_VAL << index); 4092 IXGBE_WRITE_REG(hw, IXGBE_IVAR_MISC, ivar); 4093 } else { 4094 /* tx or rx causes */ 4095 index = ((16 * (intr_alloc_entry & 1)) + (8 * cause)); 4096 ivar = IXGBE_READ_REG(hw, 4097 IXGBE_IVAR(intr_alloc_entry >> 1)); 4098 ivar &= ~(IXGBE_IVAR_ALLOC_VAL << index); 4099 IXGBE_WRITE_REG(hw, IXGBE_IVAR(intr_alloc_entry >> 1), 4100 ivar); 4101 } 4102 break; 4103 default: 4104 break; 4105 } 4106 } 4107 4108 /* 4109 * ixgbe_map_intrs_to_vectors - Map different interrupts to MSI-X vectors. 4110 * 4111 * For MSI-X, here will map rx interrupt, tx interrupt and other interrupt 4112 * to vector[0 - (intr_cnt -1)]. 4113 */ 4114 static int 4115 ixgbe_map_intrs_to_vectors(ixgbe_t *ixgbe) 4116 { 4117 int i, vector = 0; 4118 4119 /* initialize vector map */ 4120 bzero(&ixgbe->vect_map, sizeof (ixgbe->vect_map)); 4121 for (i = 0; i < ixgbe->intr_cnt; i++) { 4122 ixgbe->vect_map[i].ixgbe = ixgbe; 4123 } 4124 4125 /* 4126 * non-MSI-X case is very simple: rx rings[0] on RTxQ[0], 4127 * tx rings[0] on RTxQ[1]. 4128 */ 4129 if (ixgbe->intr_type != DDI_INTR_TYPE_MSIX) { 4130 ixgbe_map_rxring_to_vector(ixgbe, 0, 0); 4131 ixgbe_map_txring_to_vector(ixgbe, 0, 1); 4132 return (IXGBE_SUCCESS); 4133 } 4134 4135 /* 4136 * Interrupts/vectors mapping for MSI-X 4137 */ 4138 4139 /* 4140 * Map other interrupt to vector 0, 4141 * Set bit in map and count the bits set. 4142 */ 4143 BT_SET(ixgbe->vect_map[vector].other_map, 0); 4144 ixgbe->vect_map[vector].other_cnt++; 4145 vector++; 4146 4147 /* 4148 * Map rx ring interrupts to vectors 4149 */ 4150 for (i = 0; i < ixgbe->num_rx_rings; i++) { 4151 ixgbe_map_rxring_to_vector(ixgbe, i, vector); 4152 vector = (vector +1) % ixgbe->intr_cnt; 4153 } 4154 4155 /* 4156 * Map tx ring interrupts to vectors 4157 */ 4158 for (i = 0; i < ixgbe->num_tx_rings; i++) { 4159 ixgbe_map_txring_to_vector(ixgbe, i, vector); 4160 vector = (vector +1) % ixgbe->intr_cnt; 4161 } 4162 4163 return (IXGBE_SUCCESS); 4164 } 4165 4166 /* 4167 * ixgbe_setup_adapter_vector - Setup the adapter interrupt vector(s). 4168 * 4169 * This relies on ring/vector mapping already set up in the 4170 * vect_map[] structures 4171 */ 4172 static void 4173 ixgbe_setup_adapter_vector(ixgbe_t *ixgbe) 4174 { 4175 struct ixgbe_hw *hw = &ixgbe->hw; 4176 ixgbe_intr_vector_t *vect; /* vector bitmap */ 4177 int r_idx; /* ring index */ 4178 int v_idx; /* vector index */ 4179 4180 /* 4181 * Clear any previous entries 4182 */ 4183 switch (hw->mac.type) { 4184 case ixgbe_mac_82598EB: 4185 for (v_idx = 0; v_idx < 25; v_idx++) 4186 IXGBE_WRITE_REG(hw, IXGBE_IVAR(v_idx), 0); 4187 4188 break; 4189 case ixgbe_mac_82599EB: 4190 for (v_idx = 0; v_idx < 64; v_idx++) 4191 IXGBE_WRITE_REG(hw, IXGBE_IVAR(v_idx), 0); 4192 IXGBE_WRITE_REG(hw, IXGBE_IVAR_MISC, 0); 4193 4194 break; 4195 default: 4196 break; 4197 } 4198 4199 /* 4200 * For non MSI-X interrupt, rx rings[0] will use RTxQ[0], and 4201 * tx rings[0] will use RTxQ[1]. 4202 */ 4203 if (ixgbe->intr_type != DDI_INTR_TYPE_MSIX) { 4204 ixgbe_setup_ivar(ixgbe, 0, 0, 0); 4205 ixgbe_setup_ivar(ixgbe, 0, 1, 1); 4206 return; 4207 } 4208 4209 /* 4210 * For MSI-X interrupt, "Other" is always on vector[0]. 4211 */ 4212 ixgbe_setup_ivar(ixgbe, IXGBE_IVAR_OTHER_CAUSES_INDEX, 0, -1); 4213 4214 /* 4215 * For each interrupt vector, populate the IVAR table 4216 */ 4217 for (v_idx = 0; v_idx < ixgbe->intr_cnt; v_idx++) { 4218 vect = &ixgbe->vect_map[v_idx]; 4219 4220 /* 4221 * For each rx ring bit set 4222 */ 4223 r_idx = bt_getlowbit(vect->rx_map, 0, 4224 (ixgbe->num_rx_rings - 1)); 4225 4226 while (r_idx >= 0) { 4227 ixgbe_setup_ivar(ixgbe, r_idx, v_idx, 0); 4228 r_idx = bt_getlowbit(vect->rx_map, (r_idx + 1), 4229 (ixgbe->num_rx_rings - 1)); 4230 } 4231 4232 /* 4233 * For each tx ring bit set 4234 */ 4235 r_idx = bt_getlowbit(vect->tx_map, 0, 4236 (ixgbe->num_tx_rings - 1)); 4237 4238 while (r_idx >= 0) { 4239 ixgbe_setup_ivar(ixgbe, r_idx, v_idx, 1); 4240 r_idx = bt_getlowbit(vect->tx_map, (r_idx + 1), 4241 (ixgbe->num_tx_rings - 1)); 4242 } 4243 } 4244 } 4245 4246 /* 4247 * ixgbe_rem_intr_handlers - Remove the interrupt handlers. 4248 */ 4249 static void 4250 ixgbe_rem_intr_handlers(ixgbe_t *ixgbe) 4251 { 4252 int i; 4253 int rc; 4254 4255 for (i = 0; i < ixgbe->intr_cnt; i++) { 4256 rc = ddi_intr_remove_handler(ixgbe->htable[i]); 4257 if (rc != DDI_SUCCESS) { 4258 IXGBE_DEBUGLOG_1(ixgbe, 4259 "Remove intr handler failed: %d", rc); 4260 } 4261 } 4262 } 4263 4264 /* 4265 * ixgbe_rem_intrs - Remove the allocated interrupts. 4266 */ 4267 static void 4268 ixgbe_rem_intrs(ixgbe_t *ixgbe) 4269 { 4270 int i; 4271 int rc; 4272 4273 for (i = 0; i < ixgbe->intr_cnt; i++) { 4274 rc = ddi_intr_free(ixgbe->htable[i]); 4275 if (rc != DDI_SUCCESS) { 4276 IXGBE_DEBUGLOG_1(ixgbe, 4277 "Free intr failed: %d", rc); 4278 } 4279 } 4280 4281 kmem_free(ixgbe->htable, ixgbe->intr_size); 4282 ixgbe->htable = NULL; 4283 } 4284 4285 /* 4286 * ixgbe_enable_intrs - Enable all the ddi interrupts. 4287 */ 4288 static int 4289 ixgbe_enable_intrs(ixgbe_t *ixgbe) 4290 { 4291 int i; 4292 int rc; 4293 4294 /* 4295 * Enable interrupts 4296 */ 4297 if (ixgbe->intr_cap & DDI_INTR_FLAG_BLOCK) { 4298 /* 4299 * Call ddi_intr_block_enable() for MSI 4300 */ 4301 rc = ddi_intr_block_enable(ixgbe->htable, ixgbe->intr_cnt); 4302 if (rc != DDI_SUCCESS) { 4303 ixgbe_log(ixgbe, 4304 "Enable block intr failed: %d", rc); 4305 return (IXGBE_FAILURE); 4306 } 4307 } else { 4308 /* 4309 * Call ddi_intr_enable() for Legacy/MSI non block enable 4310 */ 4311 for (i = 0; i < ixgbe->intr_cnt; i++) { 4312 rc = ddi_intr_enable(ixgbe->htable[i]); 4313 if (rc != DDI_SUCCESS) { 4314 ixgbe_log(ixgbe, 4315 "Enable intr failed: %d", rc); 4316 return (IXGBE_FAILURE); 4317 } 4318 } 4319 } 4320 4321 return (IXGBE_SUCCESS); 4322 } 4323 4324 /* 4325 * ixgbe_disable_intrs - Disable all the interrupts. 4326 */ 4327 static int 4328 ixgbe_disable_intrs(ixgbe_t *ixgbe) 4329 { 4330 int i; 4331 int rc; 4332 4333 /* 4334 * Disable all interrupts 4335 */ 4336 if (ixgbe->intr_cap & DDI_INTR_FLAG_BLOCK) { 4337 rc = ddi_intr_block_disable(ixgbe->htable, ixgbe->intr_cnt); 4338 if (rc != DDI_SUCCESS) { 4339 ixgbe_log(ixgbe, 4340 "Disable block intr failed: %d", rc); 4341 return (IXGBE_FAILURE); 4342 } 4343 } else { 4344 for (i = 0; i < ixgbe->intr_cnt; i++) { 4345 rc = ddi_intr_disable(ixgbe->htable[i]); 4346 if (rc != DDI_SUCCESS) { 4347 ixgbe_log(ixgbe, 4348 "Disable intr failed: %d", rc); 4349 return (IXGBE_FAILURE); 4350 } 4351 } 4352 } 4353 4354 return (IXGBE_SUCCESS); 4355 } 4356 4357 /* 4358 * ixgbe_get_hw_state - Get and save parameters related to adapter hardware. 4359 */ 4360 static void 4361 ixgbe_get_hw_state(ixgbe_t *ixgbe) 4362 { 4363 struct ixgbe_hw *hw = &ixgbe->hw; 4364 ixgbe_link_speed speed = IXGBE_LINK_SPEED_UNKNOWN; 4365 boolean_t link_up = B_FALSE; 4366 uint32_t pcs1g_anlp = 0; 4367 uint32_t pcs1g_ana = 0; 4368 4369 ASSERT(mutex_owned(&ixgbe->gen_lock)); 4370 ixgbe->param_lp_1000fdx_cap = 0; 4371 ixgbe->param_lp_100fdx_cap = 0; 4372 4373 /* check for link, don't wait */ 4374 (void) ixgbe_check_link(hw, &speed, &link_up, false); 4375 if (link_up) { 4376 pcs1g_anlp = IXGBE_READ_REG(hw, IXGBE_PCS1GANLP); 4377 pcs1g_ana = IXGBE_READ_REG(hw, IXGBE_PCS1GANA); 4378 4379 ixgbe->param_lp_1000fdx_cap = 4380 (pcs1g_anlp & IXGBE_PCS1GANLP_LPFD) ? 1 : 0; 4381 ixgbe->param_lp_100fdx_cap = 4382 (pcs1g_anlp & IXGBE_PCS1GANLP_LPFD) ? 1 : 0; 4383 } 4384 4385 ixgbe->param_adv_1000fdx_cap = 4386 (pcs1g_ana & IXGBE_PCS1GANA_FDC) ? 1 : 0; 4387 ixgbe->param_adv_100fdx_cap = (pcs1g_ana & IXGBE_PCS1GANA_FDC) ? 1 : 0; 4388 } 4389 4390 /* 4391 * ixgbe_get_driver_control - Notify that driver is in control of device. 4392 */ 4393 static void 4394 ixgbe_get_driver_control(struct ixgbe_hw *hw) 4395 { 4396 uint32_t ctrl_ext; 4397 4398 /* 4399 * Notify firmware that driver is in control of device 4400 */ 4401 ctrl_ext = IXGBE_READ_REG(hw, IXGBE_CTRL_EXT); 4402 ctrl_ext |= IXGBE_CTRL_EXT_DRV_LOAD; 4403 IXGBE_WRITE_REG(hw, IXGBE_CTRL_EXT, ctrl_ext); 4404 } 4405 4406 /* 4407 * ixgbe_release_driver_control - Notify that driver is no longer in control 4408 * of device. 4409 */ 4410 static void 4411 ixgbe_release_driver_control(struct ixgbe_hw *hw) 4412 { 4413 uint32_t ctrl_ext; 4414 4415 /* 4416 * Notify firmware that driver is no longer in control of device 4417 */ 4418 ctrl_ext = IXGBE_READ_REG(hw, IXGBE_CTRL_EXT); 4419 ctrl_ext &= ~IXGBE_CTRL_EXT_DRV_LOAD; 4420 IXGBE_WRITE_REG(hw, IXGBE_CTRL_EXT, ctrl_ext); 4421 } 4422 4423 /* 4424 * ixgbe_atomic_reserve - Atomic decrease operation. 4425 */ 4426 int 4427 ixgbe_atomic_reserve(uint32_t *count_p, uint32_t n) 4428 { 4429 uint32_t oldval; 4430 uint32_t newval; 4431 4432 /* 4433 * ATOMICALLY 4434 */ 4435 do { 4436 oldval = *count_p; 4437 if (oldval < n) 4438 return (-1); 4439 newval = oldval - n; 4440 } while (atomic_cas_32(count_p, oldval, newval) != oldval); 4441 4442 return (newval); 4443 } 4444 4445 /* 4446 * ixgbe_mc_table_itr - Traverse the entries in the multicast table. 4447 */ 4448 static uint8_t * 4449 ixgbe_mc_table_itr(struct ixgbe_hw *hw, uint8_t **upd_ptr, uint32_t *vmdq) 4450 { 4451 uint8_t *addr = *upd_ptr; 4452 uint8_t *new_ptr; 4453 4454 _NOTE(ARGUNUSED(hw)); 4455 _NOTE(ARGUNUSED(vmdq)); 4456 4457 new_ptr = addr + IXGBE_ETH_LENGTH_OF_ADDRESS; 4458 *upd_ptr = new_ptr; 4459 return (addr); 4460 } 4461 4462 /* 4463 * FMA support 4464 */ 4465 int 4466 ixgbe_check_acc_handle(ddi_acc_handle_t handle) 4467 { 4468 ddi_fm_error_t de; 4469 4470 ddi_fm_acc_err_get(handle, &de, DDI_FME_VERSION); 4471 ddi_fm_acc_err_clear(handle, DDI_FME_VERSION); 4472 return (de.fme_status); 4473 } 4474 4475 int 4476 ixgbe_check_dma_handle(ddi_dma_handle_t handle) 4477 { 4478 ddi_fm_error_t de; 4479 4480 ddi_fm_dma_err_get(handle, &de, DDI_FME_VERSION); 4481 return (de.fme_status); 4482 } 4483 4484 /* 4485 * ixgbe_fm_error_cb - The IO fault service error handling callback function. 4486 */ 4487 static int 4488 ixgbe_fm_error_cb(dev_info_t *dip, ddi_fm_error_t *err, const void *impl_data) 4489 { 4490 _NOTE(ARGUNUSED(impl_data)); 4491 /* 4492 * as the driver can always deal with an error in any dma or 4493 * access handle, we can just return the fme_status value. 4494 */ 4495 pci_ereport_post(dip, err, NULL); 4496 return (err->fme_status); 4497 } 4498 4499 static void 4500 ixgbe_fm_init(ixgbe_t *ixgbe) 4501 { 4502 ddi_iblock_cookie_t iblk; 4503 int fma_acc_flag, fma_dma_flag; 4504 4505 /* 4506 * Only register with IO Fault Services if we have some capability 4507 */ 4508 if (ixgbe->fm_capabilities & DDI_FM_ACCCHK_CAPABLE) { 4509 ixgbe_regs_acc_attr.devacc_attr_access = DDI_FLAGERR_ACC; 4510 fma_acc_flag = 1; 4511 } else { 4512 ixgbe_regs_acc_attr.devacc_attr_access = DDI_DEFAULT_ACC; 4513 fma_acc_flag = 0; 4514 } 4515 4516 if (ixgbe->fm_capabilities & DDI_FM_DMACHK_CAPABLE) { 4517 fma_dma_flag = 1; 4518 } else { 4519 fma_dma_flag = 0; 4520 } 4521 4522 ixgbe_set_fma_flags(fma_acc_flag, fma_dma_flag); 4523 4524 if (ixgbe->fm_capabilities) { 4525 4526 /* 4527 * Register capabilities with IO Fault Services 4528 */ 4529 ddi_fm_init(ixgbe->dip, &ixgbe->fm_capabilities, &iblk); 4530 4531 /* 4532 * Initialize pci ereport capabilities if ereport capable 4533 */ 4534 if (DDI_FM_EREPORT_CAP(ixgbe->fm_capabilities) || 4535 DDI_FM_ERRCB_CAP(ixgbe->fm_capabilities)) 4536 pci_ereport_setup(ixgbe->dip); 4537 4538 /* 4539 * Register error callback if error callback capable 4540 */ 4541 if (DDI_FM_ERRCB_CAP(ixgbe->fm_capabilities)) 4542 ddi_fm_handler_register(ixgbe->dip, 4543 ixgbe_fm_error_cb, (void*) ixgbe); 4544 } 4545 } 4546 4547 static void 4548 ixgbe_fm_fini(ixgbe_t *ixgbe) 4549 { 4550 /* 4551 * Only unregister FMA capabilities if they are registered 4552 */ 4553 if (ixgbe->fm_capabilities) { 4554 4555 /* 4556 * Release any resources allocated by pci_ereport_setup() 4557 */ 4558 if (DDI_FM_EREPORT_CAP(ixgbe->fm_capabilities) || 4559 DDI_FM_ERRCB_CAP(ixgbe->fm_capabilities)) 4560 pci_ereport_teardown(ixgbe->dip); 4561 4562 /* 4563 * Un-register error callback if error callback capable 4564 */ 4565 if (DDI_FM_ERRCB_CAP(ixgbe->fm_capabilities)) 4566 ddi_fm_handler_unregister(ixgbe->dip); 4567 4568 /* 4569 * Unregister from IO Fault Service 4570 */ 4571 ddi_fm_fini(ixgbe->dip); 4572 } 4573 } 4574 4575 void 4576 ixgbe_fm_ereport(ixgbe_t *ixgbe, char *detail) 4577 { 4578 uint64_t ena; 4579 char buf[FM_MAX_CLASS]; 4580 4581 (void) snprintf(buf, FM_MAX_CLASS, "%s.%s", DDI_FM_DEVICE, detail); 4582 ena = fm_ena_generate(0, FM_ENA_FMT1); 4583 if (DDI_FM_EREPORT_CAP(ixgbe->fm_capabilities)) { 4584 ddi_fm_ereport_post(ixgbe->dip, buf, ena, DDI_NOSLEEP, 4585 FM_VERSION, DATA_TYPE_UINT8, FM_EREPORT_VERS0, NULL); 4586 } 4587 } 4588 4589 static int 4590 ixgbe_ring_start(mac_ring_driver_t rh, uint64_t mr_gen_num) 4591 { 4592 ixgbe_rx_ring_t *rx_ring = (ixgbe_rx_ring_t *)rh; 4593 4594 mutex_enter(&rx_ring->rx_lock); 4595 rx_ring->ring_gen_num = mr_gen_num; 4596 mutex_exit(&rx_ring->rx_lock); 4597 return (0); 4598 } 4599 4600 /* 4601 * Callback funtion for MAC layer to register all rings. 4602 */ 4603 /* ARGSUSED */ 4604 void 4605 ixgbe_fill_ring(void *arg, mac_ring_type_t rtype, const int rg_index, 4606 const int ring_index, mac_ring_info_t *infop, mac_ring_handle_t rh) 4607 { 4608 ixgbe_t *ixgbe = (ixgbe_t *)arg; 4609 mac_intr_t *mintr = &infop->mri_intr; 4610 4611 switch (rtype) { 4612 case MAC_RING_TYPE_RX: { 4613 ASSERT(rg_index == 0); 4614 ASSERT(ring_index < ixgbe->num_rx_rings); 4615 4616 ixgbe_rx_ring_t *rx_ring = &ixgbe->rx_rings[ring_index]; 4617 rx_ring->ring_handle = rh; 4618 4619 infop->mri_driver = (mac_ring_driver_t)rx_ring; 4620 infop->mri_start = ixgbe_ring_start; 4621 infop->mri_stop = NULL; 4622 infop->mri_poll = ixgbe_ring_rx_poll; 4623 4624 mintr->mi_handle = (mac_intr_handle_t)rx_ring; 4625 mintr->mi_enable = ixgbe_rx_ring_intr_enable; 4626 mintr->mi_disable = ixgbe_rx_ring_intr_disable; 4627 4628 break; 4629 } 4630 case MAC_RING_TYPE_TX: { 4631 ASSERT(rg_index == -1); 4632 ASSERT(ring_index < ixgbe->num_tx_rings); 4633 4634 ixgbe_tx_ring_t *tx_ring = &ixgbe->tx_rings[ring_index]; 4635 tx_ring->ring_handle = rh; 4636 4637 infop->mri_driver = (mac_ring_driver_t)tx_ring; 4638 infop->mri_start = NULL; 4639 infop->mri_stop = NULL; 4640 infop->mri_tx = ixgbe_ring_tx; 4641 4642 break; 4643 } 4644 default: 4645 break; 4646 } 4647 } 4648 4649 /* 4650 * Callback funtion for MAC layer to register all groups. 4651 */ 4652 void 4653 ixgbe_fill_group(void *arg, mac_ring_type_t rtype, const int index, 4654 mac_group_info_t *infop, mac_group_handle_t gh) 4655 { 4656 ixgbe_t *ixgbe = (ixgbe_t *)arg; 4657 4658 switch (rtype) { 4659 case MAC_RING_TYPE_RX: { 4660 ixgbe_rx_group_t *rx_group; 4661 4662 rx_group = &ixgbe->rx_groups[index]; 4663 rx_group->group_handle = gh; 4664 4665 infop->mgi_driver = (mac_group_driver_t)rx_group; 4666 infop->mgi_start = NULL; 4667 infop->mgi_stop = NULL; 4668 infop->mgi_addmac = ixgbe_addmac; 4669 infop->mgi_remmac = ixgbe_remmac; 4670 infop->mgi_count = (ixgbe->num_rx_rings / ixgbe->num_rx_groups); 4671 4672 break; 4673 } 4674 case MAC_RING_TYPE_TX: 4675 break; 4676 default: 4677 break; 4678 } 4679 } 4680 4681 /* 4682 * Enable interrupt on the specificed rx ring. 4683 */ 4684 int 4685 ixgbe_rx_ring_intr_enable(mac_intr_handle_t intrh) 4686 { 4687 ixgbe_rx_ring_t *rx_ring = (ixgbe_rx_ring_t *)intrh; 4688 ixgbe_t *ixgbe = rx_ring->ixgbe; 4689 int r_idx = rx_ring->index; 4690 int v_idx = rx_ring->intr_vector; 4691 4692 mutex_enter(&ixgbe->gen_lock); 4693 ASSERT(BT_TEST(ixgbe->vect_map[v_idx].rx_map, r_idx) == 0); 4694 4695 /* 4696 * To enable interrupt by setting the VAL bit of given interrupt 4697 * vector allocation register (IVAR). 4698 */ 4699 ixgbe_enable_ivar(ixgbe, r_idx, 0); 4700 4701 BT_SET(ixgbe->vect_map[v_idx].rx_map, r_idx); 4702 4703 /* 4704 * To trigger a Rx interrupt to on this ring 4705 */ 4706 IXGBE_WRITE_REG(&ixgbe->hw, IXGBE_EICS, (1 << v_idx)); 4707 IXGBE_WRITE_FLUSH(&ixgbe->hw); 4708 4709 mutex_exit(&ixgbe->gen_lock); 4710 4711 return (0); 4712 } 4713 4714 /* 4715 * Disable interrupt on the specificed rx ring. 4716 */ 4717 int 4718 ixgbe_rx_ring_intr_disable(mac_intr_handle_t intrh) 4719 { 4720 ixgbe_rx_ring_t *rx_ring = (ixgbe_rx_ring_t *)intrh; 4721 ixgbe_t *ixgbe = rx_ring->ixgbe; 4722 int r_idx = rx_ring->index; 4723 int v_idx = rx_ring->intr_vector; 4724 4725 mutex_enter(&ixgbe->gen_lock); 4726 ASSERT(BT_TEST(ixgbe->vect_map[v_idx].rx_map, r_idx) == 1); 4727 4728 /* 4729 * To disable interrupt by clearing the VAL bit of given interrupt 4730 * vector allocation register (IVAR). 4731 */ 4732 ixgbe_disable_ivar(ixgbe, r_idx, 0); 4733 4734 BT_CLEAR(ixgbe->vect_map[v_idx].rx_map, r_idx); 4735 4736 mutex_exit(&ixgbe->gen_lock); 4737 4738 return (0); 4739 } 4740 4741 /* 4742 * Add a mac address. 4743 */ 4744 static int 4745 ixgbe_addmac(void *arg, const uint8_t *mac_addr) 4746 { 4747 ixgbe_rx_group_t *rx_group = (ixgbe_rx_group_t *)arg; 4748 ixgbe_t *ixgbe = rx_group->ixgbe; 4749 int slot; 4750 int err; 4751 4752 mutex_enter(&ixgbe->gen_lock); 4753 4754 if (ixgbe->ixgbe_state & IXGBE_SUSPENDED) { 4755 mutex_exit(&ixgbe->gen_lock); 4756 return (ECANCELED); 4757 } 4758 4759 if (ixgbe->unicst_avail == 0) { 4760 /* no slots available */ 4761 mutex_exit(&ixgbe->gen_lock); 4762 return (ENOSPC); 4763 } 4764 4765 for (slot = 0; slot < ixgbe->unicst_total; slot++) { 4766 if (ixgbe->unicst_addr[slot].mac.set == 0) 4767 break; 4768 } 4769 4770 ASSERT((slot >= 0) && (slot < ixgbe->unicst_total)); 4771 4772 if ((err = ixgbe_unicst_set(ixgbe, mac_addr, slot)) == 0) { 4773 ixgbe->unicst_addr[slot].mac.set = 1; 4774 ixgbe->unicst_avail--; 4775 } 4776 4777 mutex_exit(&ixgbe->gen_lock); 4778 4779 return (err); 4780 } 4781 4782 /* 4783 * Remove a mac address. 4784 */ 4785 static int 4786 ixgbe_remmac(void *arg, const uint8_t *mac_addr) 4787 { 4788 ixgbe_rx_group_t *rx_group = (ixgbe_rx_group_t *)arg; 4789 ixgbe_t *ixgbe = rx_group->ixgbe; 4790 int slot; 4791 int err; 4792 4793 mutex_enter(&ixgbe->gen_lock); 4794 4795 if (ixgbe->ixgbe_state & IXGBE_SUSPENDED) { 4796 mutex_exit(&ixgbe->gen_lock); 4797 return (ECANCELED); 4798 } 4799 4800 slot = ixgbe_unicst_find(ixgbe, mac_addr); 4801 if (slot == -1) { 4802 mutex_exit(&ixgbe->gen_lock); 4803 return (EINVAL); 4804 } 4805 4806 if (ixgbe->unicst_addr[slot].mac.set == 0) { 4807 mutex_exit(&ixgbe->gen_lock); 4808 return (EINVAL); 4809 } 4810 4811 bzero(ixgbe->unicst_addr[slot].mac.addr, ETHERADDRL); 4812 if ((err = ixgbe_unicst_set(ixgbe, 4813 ixgbe->unicst_addr[slot].mac.addr, slot)) == 0) { 4814 ixgbe->unicst_addr[slot].mac.set = 0; 4815 ixgbe->unicst_avail++; 4816 } 4817 4818 mutex_exit(&ixgbe->gen_lock); 4819 4820 return (err); 4821 } 4822