1 /*- 2 * Copyright 2006-2009 Solarflare Communications Inc. All rights reserved. 3 * 4 * Redistribution and use in source and binary forms, with or without 5 * modification, are permitted provided that the following conditions 6 * are met: 7 * 1. Redistributions of source code must retain the above copyright 8 * notice, this list of conditions and the following disclaimer. 9 * 2. Redistributions in binary form must reproduce the above copyright 10 * notice, this list of conditions and the following disclaimer in the 11 * documentation and/or other materials provided with the distribution. 12 * 13 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS AND 14 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 15 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 16 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 17 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 18 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 19 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 20 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 21 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 22 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 23 * SUCH DAMAGE. 24 * 25 * $FreeBSD$ 26 */ 27 28 #ifndef _SYS_EFX_H 29 #define _SYS_EFX_H 30 31 #include "efsys.h" 32 33 #ifdef __cplusplus 34 extern "C" { 35 #endif 36 37 #define EFX_STATIC_ASSERT(_cond) ((void)sizeof(char[(_cond) ? 1 : -1])) 38 39 #define EFX_ARRAY_SIZE(_array) (sizeof(_array) / sizeof((_array)[0])) 40 41 #ifndef EFSYS_MEM_IS_NULL 42 #define EFSYS_MEM_IS_NULL(_esmp) ((_esmp)->esm_base == NULL) 43 #endif 44 45 typedef enum efx_family_e { 46 EFX_FAMILY_INVALID, 47 EFX_FAMILY_FALCON, 48 EFX_FAMILY_SIENA, 49 EFX_FAMILY_NTYPES 50 } efx_family_t; 51 52 extern __checkReturn int 53 efx_family( 54 __in uint16_t venid, 55 __in uint16_t devid, 56 __out efx_family_t *efp); 57 58 extern __checkReturn int 59 efx_infer_family( 60 __in efsys_bar_t *esbp, 61 __out efx_family_t *efp); 62 63 #define EFX_PCI_VENID_SFC 0x1924 64 #define EFX_PCI_DEVID_FALCON 0x0710 65 #define EFX_PCI_DEVID_BETHPAGE 0x0803 66 #define EFX_PCI_DEVID_SIENA 0x0813 67 #define EFX_PCI_DEVID_SIENA_F1_UNINIT 0x0810 68 69 #define EFX_MEM_BAR 2 70 71 /* Error codes */ 72 73 enum { 74 EFX_ERR_INVALID, 75 EFX_ERR_SRAM_OOB, 76 EFX_ERR_BUFID_DC_OOB, 77 EFX_ERR_MEM_PERR, 78 EFX_ERR_RBUF_OWN, 79 EFX_ERR_TBUF_OWN, 80 EFX_ERR_RDESQ_OWN, 81 EFX_ERR_TDESQ_OWN, 82 EFX_ERR_EVQ_OWN, 83 EFX_ERR_EVFF_OFLO, 84 EFX_ERR_ILL_ADDR, 85 EFX_ERR_SRAM_PERR, 86 EFX_ERR_NCODES 87 }; 88 89 /* NIC */ 90 91 typedef struct efx_nic_s efx_nic_t; 92 93 extern __checkReturn int 94 efx_nic_create( 95 __in efx_family_t family, 96 __in efsys_identifier_t *esip, 97 __in efsys_bar_t *esbp, 98 __in efsys_lock_t *eslp, 99 __deref_out efx_nic_t **enpp); 100 101 extern __checkReturn int 102 efx_nic_probe( 103 __in efx_nic_t *enp); 104 105 #if EFSYS_OPT_PCIE_TUNE 106 107 extern __checkReturn int 108 efx_nic_pcie_tune( 109 __in efx_nic_t *enp, 110 unsigned int nlanes); 111 112 extern __checkReturn int 113 efx_nic_pcie_extended_sync( 114 __in efx_nic_t *enp); 115 116 #endif /* EFSYS_OPT_PCIE_TUNE */ 117 118 extern __checkReturn int 119 efx_nic_init( 120 __in efx_nic_t *enp); 121 122 extern __checkReturn int 123 efx_nic_reset( 124 __in efx_nic_t *enp); 125 126 #if EFSYS_OPT_DIAG 127 128 extern __checkReturn int 129 efx_nic_register_test( 130 __in efx_nic_t *enp); 131 132 #endif /* EFSYS_OPT_DIAG */ 133 134 extern void 135 efx_nic_fini( 136 __in efx_nic_t *enp); 137 138 extern void 139 efx_nic_unprobe( 140 __in efx_nic_t *enp); 141 142 extern void 143 efx_nic_destroy( 144 __in efx_nic_t *enp); 145 146 #if EFSYS_OPT_MCDI 147 148 typedef struct efx_mcdi_req_s efx_mcdi_req_t; 149 150 typedef enum efx_mcdi_exception_e { 151 EFX_MCDI_EXCEPTION_MC_REBOOT, 152 EFX_MCDI_EXCEPTION_MC_BADASSERT, 153 } efx_mcdi_exception_t; 154 155 typedef struct efx_mcdi_transport_s { 156 void *emt_context; 157 void (*emt_execute)(void *, efx_mcdi_req_t *); 158 void (*emt_ev_cpl)(void *); 159 void (*emt_exception)(void *, efx_mcdi_exception_t); 160 } efx_mcdi_transport_t; 161 162 extern __checkReturn int 163 efx_mcdi_init( 164 __in efx_nic_t *enp, 165 __in const efx_mcdi_transport_t *mtp); 166 167 extern __checkReturn int 168 efx_mcdi_reboot( 169 __in efx_nic_t *enp); 170 171 extern void 172 efx_mcdi_request_start( 173 __in efx_nic_t *enp, 174 __in efx_mcdi_req_t *emrp, 175 __in boolean_t ev_cpl); 176 177 extern __checkReturn boolean_t 178 efx_mcdi_request_poll( 179 __in efx_nic_t *enp); 180 181 extern __checkReturn boolean_t 182 efx_mcdi_request_abort( 183 __in efx_nic_t *enp); 184 185 extern void 186 efx_mcdi_fini( 187 __in efx_nic_t *enp); 188 189 #endif /* EFSYS_OPT_MCDI */ 190 191 /* INTR */ 192 193 #define EFX_NINTR_FALCON 64 194 #define EFX_NINTR_SIENA 1024 195 196 typedef enum efx_intr_type_e { 197 EFX_INTR_INVALID = 0, 198 EFX_INTR_LINE, 199 EFX_INTR_MESSAGE, 200 EFX_INTR_NTYPES 201 } efx_intr_type_t; 202 203 #define EFX_INTR_SIZE (sizeof (efx_oword_t)) 204 205 extern __checkReturn int 206 efx_intr_init( 207 __in efx_nic_t *enp, 208 __in efx_intr_type_t type, 209 __in efsys_mem_t *esmp); 210 211 extern void 212 efx_intr_enable( 213 __in efx_nic_t *enp); 214 215 extern void 216 efx_intr_disable( 217 __in efx_nic_t *enp); 218 219 extern void 220 efx_intr_disable_unlocked( 221 __in efx_nic_t *enp); 222 223 #define EFX_INTR_NEVQS 32 224 225 extern __checkReturn int 226 efx_intr_trigger( 227 __in efx_nic_t *enp, 228 __in unsigned int level); 229 230 extern void 231 efx_intr_status_line( 232 __in efx_nic_t *enp, 233 __out boolean_t *fatalp, 234 __out uint32_t *maskp); 235 236 extern void 237 efx_intr_status_message( 238 __in efx_nic_t *enp, 239 __in unsigned int message, 240 __out boolean_t *fatalp); 241 242 extern void 243 efx_intr_fatal( 244 __in efx_nic_t *enp); 245 246 extern void 247 efx_intr_fini( 248 __in efx_nic_t *enp); 249 250 /* MAC */ 251 252 #if EFSYS_OPT_MAC_STATS 253 254 /* START MKCONFIG GENERATED EfxHeaderMacBlock bb8d39428b6fdcf5 */ 255 typedef enum efx_mac_stat_e { 256 EFX_MAC_RX_OCTETS, 257 EFX_MAC_RX_PKTS, 258 EFX_MAC_RX_UNICST_PKTS, 259 EFX_MAC_RX_MULTICST_PKTS, 260 EFX_MAC_RX_BRDCST_PKTS, 261 EFX_MAC_RX_PAUSE_PKTS, 262 EFX_MAC_RX_LE_64_PKTS, 263 EFX_MAC_RX_65_TO_127_PKTS, 264 EFX_MAC_RX_128_TO_255_PKTS, 265 EFX_MAC_RX_256_TO_511_PKTS, 266 EFX_MAC_RX_512_TO_1023_PKTS, 267 EFX_MAC_RX_1024_TO_15XX_PKTS, 268 EFX_MAC_RX_GE_15XX_PKTS, 269 EFX_MAC_RX_ERRORS, 270 EFX_MAC_RX_FCS_ERRORS, 271 EFX_MAC_RX_DROP_EVENTS, 272 EFX_MAC_RX_FALSE_CARRIER_ERRORS, 273 EFX_MAC_RX_SYMBOL_ERRORS, 274 EFX_MAC_RX_ALIGN_ERRORS, 275 EFX_MAC_RX_INTERNAL_ERRORS, 276 EFX_MAC_RX_JABBER_PKTS, 277 EFX_MAC_RX_LANE0_CHAR_ERR, 278 EFX_MAC_RX_LANE1_CHAR_ERR, 279 EFX_MAC_RX_LANE2_CHAR_ERR, 280 EFX_MAC_RX_LANE3_CHAR_ERR, 281 EFX_MAC_RX_LANE0_DISP_ERR, 282 EFX_MAC_RX_LANE1_DISP_ERR, 283 EFX_MAC_RX_LANE2_DISP_ERR, 284 EFX_MAC_RX_LANE3_DISP_ERR, 285 EFX_MAC_RX_MATCH_FAULT, 286 EFX_MAC_RX_NODESC_DROP_CNT, 287 EFX_MAC_TX_OCTETS, 288 EFX_MAC_TX_PKTS, 289 EFX_MAC_TX_UNICST_PKTS, 290 EFX_MAC_TX_MULTICST_PKTS, 291 EFX_MAC_TX_BRDCST_PKTS, 292 EFX_MAC_TX_PAUSE_PKTS, 293 EFX_MAC_TX_LE_64_PKTS, 294 EFX_MAC_TX_65_TO_127_PKTS, 295 EFX_MAC_TX_128_TO_255_PKTS, 296 EFX_MAC_TX_256_TO_511_PKTS, 297 EFX_MAC_TX_512_TO_1023_PKTS, 298 EFX_MAC_TX_1024_TO_15XX_PKTS, 299 EFX_MAC_TX_GE_15XX_PKTS, 300 EFX_MAC_TX_ERRORS, 301 EFX_MAC_TX_SGL_COL_PKTS, 302 EFX_MAC_TX_MULT_COL_PKTS, 303 EFX_MAC_TX_EX_COL_PKTS, 304 EFX_MAC_TX_LATE_COL_PKTS, 305 EFX_MAC_TX_DEF_PKTS, 306 EFX_MAC_TX_EX_DEF_PKTS, 307 EFX_MAC_NSTATS 308 } efx_mac_stat_t; 309 310 /* END MKCONFIG GENERATED EfxHeaderMacBlock */ 311 312 #endif /* EFSYS_OPT_MAC_STATS */ 313 314 typedef enum efx_link_mode_e { 315 EFX_LINK_UNKNOWN = 0, 316 EFX_LINK_DOWN, 317 EFX_LINK_10HDX, 318 EFX_LINK_10FDX, 319 EFX_LINK_100HDX, 320 EFX_LINK_100FDX, 321 EFX_LINK_1000HDX, 322 EFX_LINK_1000FDX, 323 EFX_LINK_10000FDX, 324 EFX_LINK_NMODES 325 } efx_link_mode_t; 326 327 #define EFX_MAC_SDU_MAX 9202 328 329 #define EFX_MAC_PDU(_sdu) \ 330 P2ROUNDUP(((_sdu) \ 331 + /* EtherII */ 14 \ 332 + /* VLAN */ 4 \ 333 + /* CRC */ 4 \ 334 + /* bug16011 */ 16), \ 335 (1 << 3)) 336 337 #define EFX_MAC_PDU_MIN 60 338 #define EFX_MAC_PDU_MAX EFX_MAC_PDU(EFX_MAC_SDU_MAX) 339 340 extern __checkReturn int 341 efx_mac_pdu_set( 342 __in efx_nic_t *enp, 343 __in size_t pdu); 344 345 extern __checkReturn int 346 efx_mac_addr_set( 347 __in efx_nic_t *enp, 348 __in uint8_t *addr); 349 350 extern __checkReturn int 351 efx_mac_filter_set( 352 __in efx_nic_t *enp, 353 __in boolean_t unicst, 354 __in boolean_t brdcst); 355 356 extern __checkReturn int 357 efx_mac_drain( 358 __in efx_nic_t *enp, 359 __in boolean_t enabled); 360 361 extern __checkReturn int 362 efx_mac_up( 363 __in efx_nic_t *enp, 364 __out boolean_t *mac_upp); 365 366 #define EFX_FCNTL_RESPOND 0x00000001 367 #define EFX_FCNTL_GENERATE 0x00000002 368 369 extern __checkReturn int 370 efx_mac_fcntl_set( 371 __in efx_nic_t *enp, 372 __in unsigned int fcntl, 373 __in boolean_t autoneg); 374 375 extern void 376 efx_mac_fcntl_get( 377 __in efx_nic_t *enp, 378 __out unsigned int *fcntl_wantedp, 379 __out unsigned int *fcntl_linkp); 380 381 #define EFX_MAC_HASH_BITS (1 << 8) 382 383 extern __checkReturn int 384 efx_mac_hash_set( 385 __in efx_nic_t *enp, 386 __in_ecount(EFX_MAC_HASH_BITS) unsigned int const *bucket); 387 388 #if EFSYS_OPT_MAC_STATS 389 390 #if EFSYS_OPT_NAMES 391 392 extern __checkReturn const char __cs * 393 efx_mac_stat_name( 394 __in efx_nic_t *enp, 395 __in unsigned int id); 396 397 #endif /* EFSYS_OPT_NAMES */ 398 399 #define EFX_MAC_STATS_SIZE 0x400 400 401 /* 402 * Upload mac statistics supported by the hardware into the given buffer. 403 * 404 * The reference buffer must be at least %EFX_MAC_STATS_SIZE bytes, 405 * and page aligned. 406 * 407 * The hardware will only DMA statistics that it understands (of course). 408 * Drivers should not make any assumptions about which statistics are 409 * supported, especially when the statistics are generated by firmware. 410 * 411 * Thus, drivers should zero this buffer before use, so that not-understood 412 * statistics read back as zero. 413 */ 414 extern __checkReturn int 415 efx_mac_stats_upload( 416 __in efx_nic_t *enp, 417 __in efsys_mem_t *esmp); 418 419 extern __checkReturn int 420 efx_mac_stats_periodic( 421 __in efx_nic_t *enp, 422 __in efsys_mem_t *esmp, 423 __in uint16_t period_ms, 424 __in boolean_t events); 425 426 extern __checkReturn int 427 efx_mac_stats_update( 428 __in efx_nic_t *enp, 429 __in efsys_mem_t *esmp, 430 __inout_ecount(EFX_MAC_NSTATS) efsys_stat_t *stat, 431 __out_opt uint32_t *generationp); 432 433 #endif /* EFSYS_OPT_MAC_STATS */ 434 435 /* MON */ 436 437 typedef enum efx_mon_type_e { 438 EFX_MON_INVALID = 0, 439 EFX_MON_NULL, 440 EFX_MON_LM87, 441 EFX_MON_MAX6647, 442 EFX_MON_SFC90X0, 443 EFX_MON_NTYPES 444 } efx_mon_type_t; 445 446 #if EFSYS_OPT_NAMES 447 448 extern const char __cs * 449 efx_mon_name( 450 __in efx_nic_t *enp); 451 452 #endif /* EFSYS_OPT_NAMES */ 453 454 extern __checkReturn int 455 efx_mon_init( 456 __in efx_nic_t *enp); 457 458 #if EFSYS_OPT_MON_STATS 459 460 #define EFX_MON_STATS_SIZE 0x100 461 462 /* START MKCONFIG GENERATED MonitorHeaderStatsBlock 16a14e61aa4f8d80 */ 463 typedef enum efx_mon_stat_e { 464 EFX_MON_STAT_2_5V, 465 EFX_MON_STAT_VCCP1, 466 EFX_MON_STAT_VCC, 467 EFX_MON_STAT_5V, 468 EFX_MON_STAT_12V, 469 EFX_MON_STAT_VCCP2, 470 EFX_MON_STAT_EXT_TEMP, 471 EFX_MON_STAT_INT_TEMP, 472 EFX_MON_STAT_AIN1, 473 EFX_MON_STAT_AIN2, 474 EFX_MON_STAT_INT_COOLING, 475 EFX_MON_STAT_EXT_COOLING, 476 EFX_MON_STAT_1V, 477 EFX_MON_STAT_1_2V, 478 EFX_MON_STAT_1_8V, 479 EFX_MON_STAT_3_3V, 480 EFX_MON_NSTATS 481 } efx_mon_stat_t; 482 483 /* END MKCONFIG GENERATED MonitorHeaderStatsBlock */ 484 485 typedef enum efx_mon_stat_state_e { 486 EFX_MON_STAT_STATE_OK = 0, 487 EFX_MON_STAT_STATE_WARNING = 1, 488 EFX_MON_STAT_STATE_FATAL = 2, 489 EFX_MON_STAT_STATE_BROKEN = 3, 490 } efx_mon_stat_state_t; 491 492 typedef struct efx_mon_stat_value_t { 493 uint16_t emsv_value; 494 uint16_t emsv_state; 495 } efx_mon_stat_value_t; 496 497 #if EFSYS_OPT_NAMES 498 499 extern const char __cs * 500 efx_mon_stat_name( 501 __in efx_nic_t *enp, 502 __in efx_mon_stat_t id); 503 504 #endif /* EFSYS_OPT_NAMES */ 505 506 extern __checkReturn int 507 efx_mon_stats_update( 508 __in efx_nic_t *enp, 509 __in efsys_mem_t *esmp, 510 __out_ecount(EFX_MON_NSTATS) efx_mon_stat_value_t *values); 511 512 #endif /* EFSYS_OPT_MON_STATS */ 513 514 extern void 515 efx_mon_fini( 516 __in efx_nic_t *enp); 517 518 /* PHY */ 519 520 #define PMA_PMD_MMD 1 521 #define PCS_MMD 3 522 #define PHY_XS_MMD 4 523 #define DTE_XS_MMD 5 524 #define AN_MMD 7 525 #define CL22EXT_MMD 29 526 527 #define MAXMMD ((1 << 5) - 1) 528 529 /* PHY types */ 530 #define EFX_PHY_NULL 0x0 531 #define EFX_PHY_TXC43128 0x1 532 #define EFX_PHY_SFX7101 0x3 533 #define EFX_PHY_QT2022C2 0x4 534 #define EFX_PHY_SFT9001A 0x8 535 #define EFX_PHY_QT2025C 0x9 536 #define EFX_PHY_SFT9001B 0xa 537 #define EFX_PHY_QLX111V 0xc 538 539 extern __checkReturn int 540 efx_phy_verify( 541 __in efx_nic_t *enp); 542 543 #if EFSYS_OPT_PHY_LED_CONTROL 544 545 typedef enum efx_phy_led_mode_e { 546 EFX_PHY_LED_DEFAULT = 0, 547 EFX_PHY_LED_OFF, 548 EFX_PHY_LED_ON, 549 EFX_PHY_LED_FLASH, 550 EFX_PHY_LED_NMODES 551 } efx_phy_led_mode_t; 552 553 extern __checkReturn int 554 efx_phy_led_set( 555 __in efx_nic_t *enp, 556 __in efx_phy_led_mode_t mode); 557 558 #endif /* EFSYS_OPT_PHY_LED_CONTROL */ 559 560 extern __checkReturn int 561 efx_port_init( 562 __in efx_nic_t *enp); 563 564 #if EFSYS_OPT_LOOPBACK 565 566 typedef enum efx_loopback_type_e { 567 EFX_LOOPBACK_OFF = 0, 568 EFX_LOOPBACK_DATA = 1, 569 EFX_LOOPBACK_GMAC = 2, 570 EFX_LOOPBACK_XGMII = 3, 571 EFX_LOOPBACK_XGXS = 4, 572 EFX_LOOPBACK_XAUI = 5, 573 EFX_LOOPBACK_GMII = 6, 574 EFX_LOOPBACK_SGMII = 7, 575 EFX_LOOPBACK_XGBR = 8, 576 EFX_LOOPBACK_XFI = 9, 577 EFX_LOOPBACK_XAUI_FAR = 10, 578 EFX_LOOPBACK_GMII_FAR = 11, 579 EFX_LOOPBACK_SGMII_FAR = 12, 580 EFX_LOOPBACK_XFI_FAR = 13, 581 EFX_LOOPBACK_GPHY = 14, 582 EFX_LOOPBACK_PHY_XS = 15, 583 EFX_LOOPBACK_PCS = 16, 584 EFX_LOOPBACK_PMA_PMD = 17, 585 EFX_LOOPBACK_NTYPES 586 } efx_loopback_type_t; 587 588 #define EFX_LOOPBACK_MAC_MASK \ 589 ((1 << EFX_LOOPBACK_DATA) | \ 590 (1 << EFX_LOOPBACK_GMAC) | \ 591 (1 << EFX_LOOPBACK_XGMII) | \ 592 (1 << EFX_LOOPBACK_XGXS) | \ 593 (1 << EFX_LOOPBACK_XAUI) | \ 594 (1 << EFX_LOOPBACK_GMII) | \ 595 (1 << EFX_LOOPBACK_SGMII) | \ 596 (1 << EFX_LOOPBACK_XGBR) | \ 597 (1 << EFX_LOOPBACK_XFI) | \ 598 (1 << EFX_LOOPBACK_XAUI_FAR) | \ 599 (1 << EFX_LOOPBACK_GMII_FAR) | \ 600 (1 << EFX_LOOPBACK_SGMII_FAR) | \ 601 (1 << EFX_LOOPBACK_XFI_FAR)) 602 603 #define EFX_LOOPBACK_MASK \ 604 ((1 << EFX_LOOPBACK_NTYPES) - 1) 605 606 extern __checkReturn int 607 efx_port_loopback_set( 608 __in efx_nic_t *enp, 609 __in efx_link_mode_t link_mode, 610 __in efx_loopback_type_t type); 611 612 #if EFSYS_OPT_NAMES 613 614 extern __checkReturn const char __cs * 615 efx_loopback_type_name( 616 __in efx_nic_t *enp, 617 __in efx_loopback_type_t type); 618 619 #endif /* EFSYS_OPT_NAMES */ 620 621 #endif /* EFSYS_OPT_LOOPBACK */ 622 623 extern __checkReturn int 624 efx_port_poll( 625 __in efx_nic_t *enp, 626 __out efx_link_mode_t *link_modep); 627 628 extern void 629 efx_port_fini( 630 __in efx_nic_t *enp); 631 632 typedef enum efx_phy_cap_type_e { 633 EFX_PHY_CAP_INVALID = 0, 634 EFX_PHY_CAP_10HDX, 635 EFX_PHY_CAP_10FDX, 636 EFX_PHY_CAP_100HDX, 637 EFX_PHY_CAP_100FDX, 638 EFX_PHY_CAP_1000HDX, 639 EFX_PHY_CAP_1000FDX, 640 EFX_PHY_CAP_10000FDX, 641 EFX_PHY_CAP_PAUSE, 642 EFX_PHY_CAP_ASYM, 643 EFX_PHY_CAP_AN, 644 EFX_PHY_CAP_NTYPES 645 } efx_phy_cap_type_t; 646 647 648 #define EFX_PHY_CAP_CURRENT 0x00000000 649 #define EFX_PHY_CAP_DEFAULT 0x00000001 650 #define EFX_PHY_CAP_PERM 0x00000002 651 652 extern void 653 efx_phy_adv_cap_get( 654 __in efx_nic_t *enp, 655 __in uint32_t flag, 656 __out uint32_t *maskp); 657 658 extern __checkReturn int 659 efx_phy_adv_cap_set( 660 __in efx_nic_t *enp, 661 __in uint32_t mask); 662 663 extern void 664 efx_phy_lp_cap_get( 665 __in efx_nic_t *enp, 666 __out uint32_t *maskp); 667 668 extern __checkReturn int 669 efx_phy_oui_get( 670 __in efx_nic_t *enp, 671 __out uint32_t *ouip); 672 673 typedef enum efx_phy_media_type_e { 674 EFX_PHY_MEDIA_INVALID = 0, 675 EFX_PHY_MEDIA_XAUI, 676 EFX_PHY_MEDIA_CX4, 677 EFX_PHY_MEDIA_KX4, 678 EFX_PHY_MEDIA_XFP, 679 EFX_PHY_MEDIA_SFP_PLUS, 680 EFX_PHY_MEDIA_BASE_T, 681 EFX_PHY_MEDIA_NTYPES 682 } efx_phy_media_type_t; 683 684 /* Get the type of medium currently used. If the board has ports for 685 * modules, a module is present, and we recognise the media type of 686 * the module, then this will be the media type of the module. 687 * Otherwise it will be the media type of the port. 688 */ 689 extern void 690 efx_phy_media_type_get( 691 __in efx_nic_t *enp, 692 __out efx_phy_media_type_t *typep); 693 694 #if EFSYS_OPT_PHY_STATS 695 696 /* START MKCONFIG GENERATED PhyHeaderStatsBlock 30ed56ad501f8e36 */ 697 typedef enum efx_phy_stat_e { 698 EFX_PHY_STAT_OUI, 699 EFX_PHY_STAT_PMA_PMD_LINK_UP, 700 EFX_PHY_STAT_PMA_PMD_RX_FAULT, 701 EFX_PHY_STAT_PMA_PMD_TX_FAULT, 702 EFX_PHY_STAT_PMA_PMD_REV_A, 703 EFX_PHY_STAT_PMA_PMD_REV_B, 704 EFX_PHY_STAT_PMA_PMD_REV_C, 705 EFX_PHY_STAT_PMA_PMD_REV_D, 706 EFX_PHY_STAT_PCS_LINK_UP, 707 EFX_PHY_STAT_PCS_RX_FAULT, 708 EFX_PHY_STAT_PCS_TX_FAULT, 709 EFX_PHY_STAT_PCS_BER, 710 EFX_PHY_STAT_PCS_BLOCK_ERRORS, 711 EFX_PHY_STAT_PHY_XS_LINK_UP, 712 EFX_PHY_STAT_PHY_XS_RX_FAULT, 713 EFX_PHY_STAT_PHY_XS_TX_FAULT, 714 EFX_PHY_STAT_PHY_XS_ALIGN, 715 EFX_PHY_STAT_PHY_XS_SYNC_A, 716 EFX_PHY_STAT_PHY_XS_SYNC_B, 717 EFX_PHY_STAT_PHY_XS_SYNC_C, 718 EFX_PHY_STAT_PHY_XS_SYNC_D, 719 EFX_PHY_STAT_AN_LINK_UP, 720 EFX_PHY_STAT_AN_MASTER, 721 EFX_PHY_STAT_AN_LOCAL_RX_OK, 722 EFX_PHY_STAT_AN_REMOTE_RX_OK, 723 EFX_PHY_STAT_CL22EXT_LINK_UP, 724 EFX_PHY_STAT_SNR_A, 725 EFX_PHY_STAT_SNR_B, 726 EFX_PHY_STAT_SNR_C, 727 EFX_PHY_STAT_SNR_D, 728 EFX_PHY_STAT_PMA_PMD_SIGNAL_A, 729 EFX_PHY_STAT_PMA_PMD_SIGNAL_B, 730 EFX_PHY_STAT_PMA_PMD_SIGNAL_C, 731 EFX_PHY_STAT_PMA_PMD_SIGNAL_D, 732 EFX_PHY_STAT_AN_COMPLETE, 733 EFX_PHY_STAT_PMA_PMD_REV_MAJOR, 734 EFX_PHY_STAT_PMA_PMD_REV_MINOR, 735 EFX_PHY_STAT_PMA_PMD_REV_MICRO, 736 EFX_PHY_STAT_PCS_FW_VERSION_0, 737 EFX_PHY_STAT_PCS_FW_VERSION_1, 738 EFX_PHY_STAT_PCS_FW_VERSION_2, 739 EFX_PHY_STAT_PCS_FW_VERSION_3, 740 EFX_PHY_STAT_PCS_FW_BUILD_YY, 741 EFX_PHY_STAT_PCS_FW_BUILD_MM, 742 EFX_PHY_STAT_PCS_FW_BUILD_DD, 743 EFX_PHY_STAT_PCS_OP_MODE, 744 EFX_PHY_NSTATS 745 } efx_phy_stat_t; 746 747 /* END MKCONFIG GENERATED PhyHeaderStatsBlock */ 748 749 #if EFSYS_OPT_NAMES 750 751 extern const char __cs * 752 efx_phy_stat_name( 753 __in efx_nic_t *enp, 754 __in efx_phy_stat_t stat); 755 756 #endif /* EFSYS_OPT_NAMES */ 757 758 #define EFX_PHY_STATS_SIZE 0x100 759 760 extern __checkReturn int 761 efx_phy_stats_update( 762 __in efx_nic_t *enp, 763 __in efsys_mem_t *esmp, 764 __out_ecount(EFX_PHY_NSTATS) uint32_t *stat); 765 766 #endif /* EFSYS_OPT_PHY_STATS */ 767 768 #if EFSYS_OPT_PHY_PROPS 769 770 #if EFSYS_OPT_NAMES 771 772 extern const char __cs * 773 efx_phy_prop_name( 774 __in efx_nic_t *enp, 775 __in unsigned int id); 776 777 #endif /* EFSYS_OPT_NAMES */ 778 779 #define EFX_PHY_PROP_DEFAULT 0x00000001 780 781 extern __checkReturn int 782 efx_phy_prop_get( 783 __in efx_nic_t *enp, 784 __in unsigned int id, 785 __in uint32_t flags, 786 __out uint32_t *valp); 787 788 extern __checkReturn int 789 efx_phy_prop_set( 790 __in efx_nic_t *enp, 791 __in unsigned int id, 792 __in uint32_t val); 793 794 #endif /* EFSYS_OPT_PHY_PROPS */ 795 796 #if EFSYS_OPT_PHY_BIST 797 798 typedef enum efx_phy_bist_type_e { 799 EFX_PHY_BIST_TYPE_UNKNOWN, 800 EFX_PHY_BIST_TYPE_NORMAL, 801 EFX_PHY_BIST_TYPE_CABLE_SHORT, 802 EFX_PHY_BIST_TYPE_CABLE_LONG, 803 EFX_PHY_BIST_TYPE_NTYPES, 804 } efx_phy_bist_type_t; 805 806 typedef enum efx_phy_bist_result_e { 807 EFX_PHY_BIST_RESULT_UNKNOWN, 808 EFX_PHY_BIST_RESULT_RUNNING, 809 EFX_PHY_BIST_RESULT_PASSED, 810 EFX_PHY_BIST_RESULT_FAILED, 811 } efx_phy_bist_result_t; 812 813 typedef enum efx_phy_cable_status_e { 814 EFX_PHY_CABLE_STATUS_OK, 815 EFX_PHY_CABLE_STATUS_INVALID, 816 EFX_PHY_CABLE_STATUS_OPEN, 817 EFX_PHY_CABLE_STATUS_INTRAPAIRSHORT, 818 EFX_PHY_CABLE_STATUS_INTERPAIRSHORT, 819 EFX_PHY_CABLE_STATUS_BUSY, 820 } efx_phy_cable_status_t; 821 822 typedef enum efx_phy_bist_value_e { 823 EFX_PHY_BIST_CABLE_LENGTH_A, 824 EFX_PHY_BIST_CABLE_LENGTH_B, 825 EFX_PHY_BIST_CABLE_LENGTH_C, 826 EFX_PHY_BIST_CABLE_LENGTH_D, 827 EFX_PHY_BIST_CABLE_STATUS_A, 828 EFX_PHY_BIST_CABLE_STATUS_B, 829 EFX_PHY_BIST_CABLE_STATUS_C, 830 EFX_PHY_BIST_CABLE_STATUS_D, 831 EFX_PHY_BIST_FAULT_CODE, 832 EFX_PHY_BIST_NVALUES, 833 } efx_phy_bist_value_t; 834 835 extern __checkReturn int 836 efx_phy_bist_start( 837 __in efx_nic_t *enp, 838 __in efx_phy_bist_type_t type); 839 840 extern __checkReturn int 841 efx_phy_bist_poll( 842 __in efx_nic_t *enp, 843 __in efx_phy_bist_type_t type, 844 __out efx_phy_bist_result_t *resultp, 845 __out_opt uint32_t *value_maskp, 846 __out_ecount_opt(count) unsigned long *valuesp, 847 __in size_t count); 848 849 extern void 850 efx_phy_bist_stop( 851 __in efx_nic_t *enp, 852 __in efx_phy_bist_type_t type); 853 854 #endif /* EFSYS_OPT_PHY_BIST */ 855 856 #define EFX_FEATURE_IPV6 0x00000001 857 #define EFX_FEATURE_LFSR_HASH_INSERT 0x00000002 858 #define EFX_FEATURE_LINK_EVENTS 0x00000004 859 #define EFX_FEATURE_PERIODIC_MAC_STATS 0x00000008 860 #define EFX_FEATURE_WOL 0x00000010 861 #define EFX_FEATURE_MCDI 0x00000020 862 #define EFX_FEATURE_LOOKAHEAD_SPLIT 0x00000040 863 #define EFX_FEATURE_MAC_HEADER_FILTERS 0x00000080 864 865 typedef struct efx_nic_cfg_s { 866 uint32_t enc_board_type; 867 uint32_t enc_phy_type; 868 #if EFSYS_OPT_NAMES 869 char enc_phy_name[21]; 870 #endif 871 char enc_phy_revision[21]; 872 efx_mon_type_t enc_mon_type; 873 #if EFSYS_OPT_MON_STATS 874 uint32_t enc_mon_stat_mask; 875 #endif 876 unsigned int enc_features; 877 uint8_t enc_mac_addr[6]; 878 uint8_t enc_port; 879 uint32_t enc_evq_limit; 880 uint32_t enc_txq_limit; 881 uint32_t enc_rxq_limit; 882 uint32_t enc_buftbl_limit; 883 uint32_t enc_evq_moderation_max; 884 #if EFSYS_OPT_LOOPBACK 885 uint32_t enc_loopback_types[EFX_LINK_NMODES]; 886 #endif /* EFSYS_OPT_LOOPBACK */ 887 #if EFSYS_OPT_PHY_FLAGS 888 uint32_t enc_phy_flags_mask; 889 #endif /* EFSYS_OPT_PHY_FLAGS */ 890 #if EFSYS_OPT_PHY_LED_CONTROL 891 uint32_t enc_led_mask; 892 #endif /* EFSYS_OPT_PHY_LED_CONTROL */ 893 #if EFSYS_OPT_PHY_STATS 894 uint64_t enc_phy_stat_mask; 895 #endif /* EFSYS_OPT_PHY_STATS */ 896 #if EFSYS_OPT_PHY_PROPS 897 unsigned int enc_phy_nprops; 898 #endif /* EFSYS_OPT_PHY_PROPS */ 899 #if EFSYS_OPT_SIENA 900 uint8_t enc_siena_channel; 901 #if EFSYS_OPT_PHY_STATS 902 uint32_t enc_siena_phy_stat_mask; 903 #endif /* EFSYS_OPT_PHY_STATS */ 904 #if EFSYS_OPT_MON_STATS 905 uint32_t enc_siena_mon_stat_mask; 906 #endif /* EFSYS_OPT_MON_STATS */ 907 #endif /* EFSYS_OPT_SIENA */ 908 #if EFSYS_OPT_PHY_BIST 909 uint32_t enc_bist_mask; 910 #endif /* EFSYS_OPT_PHY_BIST */ 911 } efx_nic_cfg_t; 912 913 extern const efx_nic_cfg_t * 914 efx_nic_cfg_get( 915 __in efx_nic_t *enp); 916 917 #if EFSYS_OPT_VPD 918 919 typedef enum efx_vpd_tag_e { 920 EFX_VPD_ID = 0x02, 921 EFX_VPD_END = 0x0f, 922 EFX_VPD_RO = 0x10, 923 EFX_VPD_RW = 0x11, 924 } efx_vpd_tag_t; 925 926 typedef uint16_t efx_vpd_keyword_t; 927 928 typedef struct efx_vpd_value_s { 929 efx_vpd_tag_t evv_tag; 930 efx_vpd_keyword_t evv_keyword; 931 uint8_t evv_length; 932 uint8_t evv_value[0x100]; 933 } efx_vpd_value_t; 934 935 936 #define EFX_VPD_KEYWORD(x, y) ((x) | ((y) << 8)) 937 938 extern __checkReturn int 939 efx_vpd_init( 940 __in efx_nic_t *enp); 941 942 extern __checkReturn int 943 efx_vpd_size( 944 __in efx_nic_t *enp, 945 __out size_t *sizep); 946 947 extern __checkReturn int 948 efx_vpd_read( 949 __in efx_nic_t *enp, 950 __out_bcount(size) caddr_t data, 951 __in size_t size); 952 953 extern __checkReturn int 954 efx_vpd_verify( 955 __in efx_nic_t *enp, 956 __in_bcount(size) caddr_t data, 957 __in size_t size); 958 959 extern __checkReturn int 960 efx_vpd_reinit( 961 __in efx_nic_t *enp, 962 __in_bcount(size) caddr_t data, 963 __in size_t size); 964 965 extern __checkReturn int 966 efx_vpd_get( 967 __in efx_nic_t *enp, 968 __in_bcount(size) caddr_t data, 969 __in size_t size, 970 __inout efx_vpd_value_t *evvp); 971 972 extern __checkReturn int 973 efx_vpd_set( 974 __in efx_nic_t *enp, 975 __inout_bcount(size) caddr_t data, 976 __in size_t size, 977 __in efx_vpd_value_t *evvp); 978 979 extern __checkReturn int 980 efx_vpd_next( 981 __in efx_nic_t *enp, 982 __inout_bcount(size) caddr_t data, 983 __in size_t size, 984 __out efx_vpd_value_t *evvp, 985 __inout unsigned int *contp); 986 987 extern __checkReturn int 988 efx_vpd_write( 989 __in efx_nic_t *enp, 990 __in_bcount(size) caddr_t data, 991 __in size_t size); 992 993 extern void 994 efx_vpd_fini( 995 __in efx_nic_t *enp); 996 997 #endif /* EFSYS_OPT_VPD */ 998 999 /* NVRAM */ 1000 1001 #if EFSYS_OPT_NVRAM 1002 1003 typedef enum efx_nvram_type_e { 1004 EFX_NVRAM_INVALID = 0, 1005 EFX_NVRAM_BOOTROM, 1006 EFX_NVRAM_BOOTROM_CFG, 1007 EFX_NVRAM_MC_FIRMWARE, 1008 EFX_NVRAM_MC_GOLDEN, 1009 EFX_NVRAM_PHY, 1010 EFX_NVRAM_NULLPHY, 1011 EFX_NVRAM_NTYPES, 1012 } efx_nvram_type_t; 1013 1014 extern __checkReturn int 1015 efx_nvram_init( 1016 __in efx_nic_t *enp); 1017 1018 #if EFSYS_OPT_DIAG 1019 1020 extern __checkReturn int 1021 efx_nvram_test( 1022 __in efx_nic_t *enp); 1023 1024 #endif /* EFSYS_OPT_DIAG */ 1025 1026 extern __checkReturn int 1027 efx_nvram_size( 1028 __in efx_nic_t *enp, 1029 __in efx_nvram_type_t type, 1030 __out size_t *sizep); 1031 1032 extern __checkReturn int 1033 efx_nvram_rw_start( 1034 __in efx_nic_t *enp, 1035 __in efx_nvram_type_t type, 1036 __out_opt size_t *pref_chunkp); 1037 1038 extern void 1039 efx_nvram_rw_finish( 1040 __in efx_nic_t *enp, 1041 __in efx_nvram_type_t type); 1042 1043 extern __checkReturn int 1044 efx_nvram_get_version( 1045 __in efx_nic_t *enp, 1046 __in efx_nvram_type_t type, 1047 __out uint32_t *subtypep, 1048 __out_ecount(4) uint16_t version[4]); 1049 1050 extern __checkReturn int 1051 efx_nvram_read_chunk( 1052 __in efx_nic_t *enp, 1053 __in efx_nvram_type_t type, 1054 __in unsigned int offset, 1055 __out_bcount(size) caddr_t data, 1056 __in size_t size); 1057 1058 extern __checkReturn int 1059 efx_nvram_set_version( 1060 __in efx_nic_t *enp, 1061 __in efx_nvram_type_t type, 1062 __out uint16_t version[4]); 1063 1064 extern __checkReturn int 1065 efx_nvram_erase( 1066 __in efx_nic_t *enp, 1067 __in efx_nvram_type_t type); 1068 1069 extern __checkReturn int 1070 efx_nvram_write_chunk( 1071 __in efx_nic_t *enp, 1072 __in efx_nvram_type_t type, 1073 __in unsigned int offset, 1074 __in_bcount(size) caddr_t data, 1075 __in size_t size); 1076 1077 extern void 1078 efx_nvram_fini( 1079 __in efx_nic_t *enp); 1080 1081 #endif /* EFSYS_OPT_NVRAM */ 1082 1083 #if EFSYS_OPT_BOOTCFG 1084 1085 extern int 1086 efx_bootcfg_read( 1087 __in efx_nic_t *enp, 1088 __out_bcount(size) caddr_t data, 1089 __in size_t size); 1090 1091 extern int 1092 efx_bootcfg_write( 1093 __in efx_nic_t *enp, 1094 __in_bcount(size) caddr_t data, 1095 __in size_t size); 1096 1097 #endif /* EFSYS_OPT_BOOTCFG */ 1098 1099 #if EFSYS_OPT_WOL 1100 1101 typedef enum efx_wol_type_e { 1102 EFX_WOL_TYPE_INVALID, 1103 EFX_WOL_TYPE_MAGIC, 1104 EFX_WOL_TYPE_BITMAP, 1105 EFX_WOL_TYPE_LINK, 1106 EFX_WOL_NTYPES, 1107 } efx_wol_type_t; 1108 1109 typedef enum efx_lightsout_offload_type_e { 1110 EFX_LIGHTSOUT_OFFLOAD_TYPE_INVALID, 1111 EFX_LIGHTSOUT_OFFLOAD_TYPE_ARP, 1112 EFX_LIGHTSOUT_OFFLOAD_TYPE_NS, 1113 } efx_lightsout_offload_type_t; 1114 1115 #define EFX_WOL_BITMAP_MASK_SIZE (48) 1116 #define EFX_WOL_BITMAP_VALUE_SIZE (128) 1117 1118 typedef union efx_wol_param_u { 1119 struct { 1120 uint8_t mac_addr[6]; 1121 } ewp_magic; 1122 struct { 1123 uint8_t mask[EFX_WOL_BITMAP_MASK_SIZE]; /* 1 bit per byte */ 1124 uint8_t value[EFX_WOL_BITMAP_VALUE_SIZE]; /* value to match */ 1125 uint8_t value_len; 1126 } ewp_bitmap; 1127 } efx_wol_param_t; 1128 1129 typedef union efx_lightsout_offload_param_u { 1130 struct { 1131 uint8_t mac_addr[6]; 1132 uint32_t ip; 1133 } elop_arp; 1134 struct { 1135 uint8_t mac_addr[6]; 1136 uint32_t solicited_node[4]; 1137 uint32_t ip[4]; 1138 } elop_ns; 1139 } efx_lightsout_offload_param_t; 1140 1141 extern __checkReturn int 1142 efx_wol_init( 1143 __in efx_nic_t *enp); 1144 1145 extern __checkReturn int 1146 efx_wol_filter_clear( 1147 __in efx_nic_t *enp); 1148 1149 extern __checkReturn int 1150 efx_wol_filter_add( 1151 __in efx_nic_t *enp, 1152 __in efx_wol_type_t type, 1153 __in efx_wol_param_t *paramp, 1154 __out uint32_t *filter_idp); 1155 1156 extern __checkReturn int 1157 efx_wol_filter_remove( 1158 __in efx_nic_t *enp, 1159 __in uint32_t filter_id); 1160 1161 extern __checkReturn int 1162 efx_lightsout_offload_add( 1163 __in efx_nic_t *enp, 1164 __in efx_lightsout_offload_type_t type, 1165 __in efx_lightsout_offload_param_t *paramp, 1166 __out uint32_t *filter_idp); 1167 1168 extern __checkReturn int 1169 efx_lightsout_offload_remove( 1170 __in efx_nic_t *enp, 1171 __in efx_lightsout_offload_type_t type, 1172 __in uint32_t filter_id); 1173 1174 extern void 1175 efx_wol_fini( 1176 __in efx_nic_t *enp); 1177 1178 #endif /* EFSYS_OPT_WOL */ 1179 1180 #if EFSYS_OPT_DIAG 1181 1182 typedef enum efx_pattern_type_t { 1183 EFX_PATTERN_BYTE_INCREMENT = 0, 1184 EFX_PATTERN_ALL_THE_SAME, 1185 EFX_PATTERN_BIT_ALTERNATE, 1186 EFX_PATTERN_BYTE_ALTERNATE, 1187 EFX_PATTERN_BYTE_CHANGING, 1188 EFX_PATTERN_BIT_SWEEP, 1189 EFX_PATTERN_NTYPES 1190 } efx_pattern_type_t; 1191 1192 typedef void 1193 (*efx_sram_pattern_fn_t)( 1194 __in size_t row, 1195 __in boolean_t negate, 1196 __out efx_qword_t *eqp); 1197 1198 extern __checkReturn int 1199 efx_sram_test( 1200 __in efx_nic_t *enp, 1201 __in efx_pattern_type_t type); 1202 1203 #endif /* EFSYS_OPT_DIAG */ 1204 1205 extern __checkReturn int 1206 efx_sram_buf_tbl_set( 1207 __in efx_nic_t *enp, 1208 __in uint32_t id, 1209 __in efsys_mem_t *esmp, 1210 __in size_t n); 1211 1212 extern void 1213 efx_sram_buf_tbl_clear( 1214 __in efx_nic_t *enp, 1215 __in uint32_t id, 1216 __in size_t n); 1217 1218 #define EFX_BUF_TBL_SIZE 0x20000 1219 1220 #define EFX_BUF_SIZE 4096 1221 1222 /* EV */ 1223 1224 typedef struct efx_evq_s efx_evq_t; 1225 1226 #if EFSYS_OPT_QSTATS 1227 1228 /* START MKCONFIG GENERATED EfxHeaderEventQueueBlock d5614a5d669c8ca3 */ 1229 typedef enum efx_ev_qstat_e { 1230 EV_ALL, 1231 EV_RX, 1232 EV_RX_OK, 1233 EV_RX_RECOVERY, 1234 EV_RX_FRM_TRUNC, 1235 EV_RX_TOBE_DISC, 1236 EV_RX_PAUSE_FRM_ERR, 1237 EV_RX_BUF_OWNER_ID_ERR, 1238 EV_RX_IPV4_HDR_CHKSUM_ERR, 1239 EV_RX_TCP_UDP_CHKSUM_ERR, 1240 EV_RX_ETH_CRC_ERR, 1241 EV_RX_IP_FRAG_ERR, 1242 EV_RX_MCAST_PKT, 1243 EV_RX_MCAST_HASH_MATCH, 1244 EV_RX_TCP_IPV4, 1245 EV_RX_TCP_IPV6, 1246 EV_RX_UDP_IPV4, 1247 EV_RX_UDP_IPV6, 1248 EV_RX_OTHER_IPV4, 1249 EV_RX_OTHER_IPV6, 1250 EV_RX_NON_IP, 1251 EV_RX_OVERRUN, 1252 EV_TX, 1253 EV_TX_WQ_FF_FULL, 1254 EV_TX_PKT_ERR, 1255 EV_TX_PKT_TOO_BIG, 1256 EV_TX_UNEXPECTED, 1257 EV_GLOBAL, 1258 EV_GLOBAL_PHY, 1259 EV_GLOBAL_MNT, 1260 EV_GLOBAL_RX_RECOVERY, 1261 EV_DRIVER, 1262 EV_DRIVER_SRM_UPD_DONE, 1263 EV_DRIVER_TX_DESCQ_FLS_DONE, 1264 EV_DRIVER_RX_DESCQ_FLS_DONE, 1265 EV_DRIVER_RX_DESCQ_FLS_FAILED, 1266 EV_DRIVER_RX_DSC_ERROR, 1267 EV_DRIVER_TX_DSC_ERROR, 1268 EV_DRV_GEN, 1269 EV_MCDI_RESPONSE, 1270 EV_NQSTATS 1271 } efx_ev_qstat_t; 1272 1273 /* END MKCONFIG GENERATED EfxHeaderEventQueueBlock */ 1274 1275 #endif /* EFSYS_OPT_QSTATS */ 1276 1277 extern __checkReturn int 1278 efx_ev_init( 1279 __in efx_nic_t *enp); 1280 1281 extern void 1282 efx_ev_fini( 1283 __in efx_nic_t *enp); 1284 1285 #define EFX_MASK(_max, _min) (-((_max) << 1) ^ -(_min)) 1286 1287 #define EFX_EVQ_MAXNEVS 32768 1288 #define EFX_EVQ_MINNEVS 512 1289 1290 #define EFX_EVQ_NEVS_MASK EFX_MASK(EFX_EVQ_MAXNEVS, EFX_EVQ_MINNEVS) 1291 1292 #define EFX_EVQ_SIZE(_nevs) ((_nevs) * sizeof (efx_qword_t)) 1293 #define EFX_EVQ_NBUFS(_nevs) (EFX_EVQ_SIZE(_nevs) / EFX_BUF_SIZE) 1294 1295 extern __checkReturn int 1296 efx_ev_qcreate( 1297 __in efx_nic_t *enp, 1298 __in unsigned int index, 1299 __in efsys_mem_t *esmp, 1300 __in size_t n, 1301 __in uint32_t id, 1302 __deref_out efx_evq_t **eepp); 1303 1304 extern void 1305 efx_ev_qpost( 1306 __in efx_evq_t *eep, 1307 __in uint16_t data); 1308 1309 typedef __checkReturn boolean_t 1310 (*efx_initialized_ev_t)( 1311 __in_opt void *arg); 1312 1313 #define EFX_PKT_UNICAST 0x0004 1314 #define EFX_PKT_START 0x0008 1315 1316 #define EFX_PKT_VLAN_TAGGED 0x0010 1317 #define EFX_CKSUM_TCPUDP 0x0020 1318 #define EFX_CKSUM_IPV4 0x0040 1319 #define EFX_PKT_CONT 0x0080 1320 1321 #define EFX_CHECK_VLAN 0x0100 1322 #define EFX_PKT_TCP 0x0200 1323 #define EFX_PKT_UDP 0x0400 1324 #define EFX_PKT_IPV4 0x0800 1325 1326 #define EFX_PKT_IPV6 0x1000 1327 #define EFX_ADDR_MISMATCH 0x4000 1328 #define EFX_DISCARD 0x8000 1329 1330 #define EFX_EV_RX_NLABELS 32 1331 #define EFX_EV_TX_NLABELS 32 1332 1333 typedef __checkReturn boolean_t 1334 (*efx_rx_ev_t)( 1335 __in_opt void *arg, 1336 __in uint32_t label, 1337 __in uint32_t id, 1338 __in uint32_t size, 1339 __in uint16_t flags); 1340 1341 typedef __checkReturn boolean_t 1342 (*efx_tx_ev_t)( 1343 __in_opt void *arg, 1344 __in uint32_t label, 1345 __in uint32_t id); 1346 1347 #define EFX_EXCEPTION_RX_RECOVERY 0x00000001 1348 #define EFX_EXCEPTION_RX_DSC_ERROR 0x00000002 1349 #define EFX_EXCEPTION_TX_DSC_ERROR 0x00000003 1350 #define EFX_EXCEPTION_UNKNOWN_SENSOREVT 0x00000004 1351 #define EFX_EXCEPTION_FWALERT_SRAM 0x00000005 1352 #define EFX_EXCEPTION_UNKNOWN_FWALERT 0x00000006 1353 1354 typedef __checkReturn boolean_t 1355 (*efx_exception_ev_t)( 1356 __in_opt void *arg, 1357 __in uint32_t label, 1358 __in uint32_t data); 1359 1360 typedef __checkReturn boolean_t 1361 (*efx_rxq_flush_done_ev_t)( 1362 __in_opt void *arg, 1363 __in uint32_t label); 1364 1365 typedef __checkReturn boolean_t 1366 (*efx_rxq_flush_failed_ev_t)( 1367 __in_opt void *arg, 1368 __in uint32_t label); 1369 1370 typedef __checkReturn boolean_t 1371 (*efx_txq_flush_done_ev_t)( 1372 __in_opt void *arg, 1373 __in uint32_t label); 1374 1375 typedef __checkReturn boolean_t 1376 (*efx_software_ev_t)( 1377 __in_opt void *arg, 1378 __in uint16_t magic); 1379 1380 typedef __checkReturn boolean_t 1381 (*efx_sram_ev_t)( 1382 __in_opt void *arg, 1383 __in uint32_t code); 1384 1385 #define EFX_SRAM_CLEAR 0 1386 #define EFX_SRAM_UPDATE 1 1387 #define EFX_SRAM_ILLEGAL_CLEAR 2 1388 1389 typedef __checkReturn boolean_t 1390 (*efx_wake_up_ev_t)( 1391 __in_opt void *arg, 1392 __in uint32_t label); 1393 1394 typedef __checkReturn boolean_t 1395 (*efx_timer_ev_t)( 1396 __in_opt void *arg, 1397 __in uint32_t label); 1398 1399 typedef __checkReturn boolean_t 1400 (*efx_link_change_ev_t)( 1401 __in_opt void *arg, 1402 __in efx_link_mode_t link_mode); 1403 1404 #if EFSYS_OPT_MON_STATS 1405 1406 typedef __checkReturn boolean_t 1407 (*efx_monitor_ev_t)( 1408 __in_opt void *arg, 1409 __in efx_mon_stat_t id, 1410 __in efx_mon_stat_value_t value); 1411 1412 #endif /* EFSYS_OPT_MON_STATS */ 1413 1414 #if EFSYS_OPT_MAC_STATS 1415 1416 typedef __checkReturn boolean_t 1417 (*efx_mac_stats_ev_t)( 1418 __in_opt void *arg, 1419 __in uint32_t generation 1420 ); 1421 1422 #endif /* EFSYS_OPT_MAC_STATS */ 1423 1424 typedef struct efx_ev_callbacks_s { 1425 efx_initialized_ev_t eec_initialized; 1426 efx_rx_ev_t eec_rx; 1427 efx_tx_ev_t eec_tx; 1428 efx_exception_ev_t eec_exception; 1429 efx_rxq_flush_done_ev_t eec_rxq_flush_done; 1430 efx_rxq_flush_failed_ev_t eec_rxq_flush_failed; 1431 efx_txq_flush_done_ev_t eec_txq_flush_done; 1432 efx_software_ev_t eec_software; 1433 efx_sram_ev_t eec_sram; 1434 efx_wake_up_ev_t eec_wake_up; 1435 efx_timer_ev_t eec_timer; 1436 efx_link_change_ev_t eec_link_change; 1437 #if EFSYS_OPT_MON_STATS 1438 efx_monitor_ev_t eec_monitor; 1439 #endif /* EFSYS_OPT_MON_STATS */ 1440 #if EFSYS_OPT_MAC_STATS 1441 efx_mac_stats_ev_t eec_mac_stats; 1442 #endif /* EFSYS_OPT_MON_STATS */ 1443 } efx_ev_callbacks_t; 1444 1445 extern __checkReturn boolean_t 1446 efx_ev_qpending( 1447 __in efx_evq_t *eep, 1448 __in unsigned int count); 1449 1450 #if EFSYS_OPT_EV_PREFETCH 1451 1452 extern void 1453 efx_ev_qprefetch( 1454 __in efx_evq_t *eep, 1455 __in unsigned int count); 1456 1457 #endif /* EFSYS_OPT_EV_PREFETCH */ 1458 1459 extern void 1460 efx_ev_qpoll( 1461 __in efx_evq_t *eep, 1462 __inout unsigned int *countp, 1463 __in const efx_ev_callbacks_t *eecp, 1464 __in_opt void *arg); 1465 1466 extern __checkReturn int 1467 efx_ev_qmoderate( 1468 __in efx_evq_t *eep, 1469 __in unsigned int us); 1470 1471 extern __checkReturn int 1472 efx_ev_qprime( 1473 __in efx_evq_t *eep, 1474 __in unsigned int count); 1475 1476 #if EFSYS_OPT_QSTATS 1477 1478 #if EFSYS_OPT_NAMES 1479 1480 extern const char __cs * 1481 efx_ev_qstat_name( 1482 __in efx_nic_t *enp, 1483 __in unsigned int id); 1484 1485 #endif /* EFSYS_OPT_NAMES */ 1486 1487 extern void 1488 efx_ev_qstats_update( 1489 __in efx_evq_t *eep, 1490 __inout_ecount(EV_NQSTATS) efsys_stat_t *stat); 1491 1492 #endif /* EFSYS_OPT_QSTATS */ 1493 1494 extern void 1495 efx_ev_qdestroy( 1496 __in efx_evq_t *eep); 1497 1498 /* RX */ 1499 1500 typedef struct efx_rxq_s efx_rxq_t; 1501 1502 extern __checkReturn int 1503 efx_rx_init( 1504 __in efx_nic_t *enp); 1505 1506 extern void 1507 efx_rx_fini( 1508 __in efx_nic_t *enp); 1509 1510 #if EFSYS_OPT_RX_HDR_SPLIT 1511 __checkReturn int 1512 efx_rx_hdr_split_enable( 1513 __in efx_nic_t *enp, 1514 __in unsigned int hdr_buf_size, 1515 __in unsigned int pld_buf_size); 1516 1517 #endif /* EFSYS_OPT_RX_HDR_SPLIT */ 1518 1519 #if EFSYS_OPT_RX_SCATTER 1520 __checkReturn int 1521 efx_rx_scatter_enable( 1522 __in efx_nic_t *enp, 1523 __in unsigned int buf_size); 1524 #endif /* EFSYS_OPT_RX_SCATTER */ 1525 1526 #if EFSYS_OPT_RX_SCALE 1527 1528 typedef enum efx_rx_hash_alg_e { 1529 EFX_RX_HASHALG_LFSR = 0, 1530 EFX_RX_HASHALG_TOEPLITZ 1531 } efx_rx_hash_alg_t; 1532 1533 typedef enum efx_rx_hash_type_e { 1534 EFX_RX_HASH_IPV4 = 0, 1535 EFX_RX_HASH_TCPIPV4, 1536 EFX_RX_HASH_IPV6, 1537 EFX_RX_HASH_TCPIPV6, 1538 } efx_rx_hash_type_t; 1539 1540 #define EFX_RSS_TBL_SIZE 128 /* Rows in RX indirection table */ 1541 #define EFX_MAXRSS 64 /* RX indirection entry range */ 1542 #define EFX_MAXRSS_LEGACY 16 /* See bug16611 and bug17213 */ 1543 1544 extern __checkReturn int 1545 efx_rx_scale_mode_set( 1546 __in efx_nic_t *enp, 1547 __in efx_rx_hash_alg_t alg, 1548 __in efx_rx_hash_type_t type, 1549 __in boolean_t insert); 1550 1551 extern __checkReturn int 1552 efx_rx_scale_tbl_set( 1553 __in efx_nic_t *enp, 1554 __in_ecount(n) unsigned int *table, 1555 __in size_t n); 1556 1557 extern __checkReturn int 1558 efx_rx_scale_toeplitz_ipv4_key_set( 1559 __in efx_nic_t *enp, 1560 __in_ecount(n) uint8_t *key, 1561 __in size_t n); 1562 1563 extern __checkReturn int 1564 efx_rx_scale_toeplitz_ipv6_key_set( 1565 __in efx_nic_t *enp, 1566 __in_ecount(n) uint8_t *key, 1567 __in size_t n); 1568 1569 /* 1570 * The prefix is a byte array of one of the forms: 1571 * 1572 * 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 1573 * XX.XX.XX.XX.XX.XX.XX.XX.XX.XX.XX.XX.TT.TT.TT.TT 1574 * XX.XX.XX.XX.XX.XX.XX.XX.XX.XX.XX.XX.XX.XX.LL.LL 1575 * 1576 * where: 1577 * 1578 * TT.TT.TT.TT is a 32-bit Toeplitz hash 1579 * LL.LL is a 16-bit LFSR hash 1580 * 1581 * Hash values are in network (big-endian) byte order. 1582 */ 1583 1584 #define EFX_RX_PREFIX_SIZE 16 1585 1586 #define EFX_RX_HASH_VALUE(_func, _buffer) \ 1587 (((_func) == EFX_RX_HASHALG_LFSR) ? \ 1588 ((uint16_t)(((_buffer)[14] << 8) | (_buffer)[15])) : \ 1589 ((uint32_t)(((_buffer)[12] << 24) | \ 1590 ((_buffer)[13] << 16) | \ 1591 ((_buffer)[14] << 8) | \ 1592 (_buffer)[15]))) 1593 1594 #define EFX_RX_HASH_SIZE(_func) \ 1595 (((_func) == EFX_RX_HASHALG_LFSR) ? \ 1596 sizeof (uint16_t) : \ 1597 sizeof (uint32_t)) 1598 1599 #endif /* EFSYS_OPT_RX_SCALE */ 1600 1601 #define EFX_RXQ_MAXNDESCS 4096 1602 #define EFX_RXQ_MINNDESCS 512 1603 1604 #define EFX_RXQ_NDESCS_MASK EFX_MASK(EFX_RXQ_MAXNDESCS, EFX_RXQ_MINNDESCS) 1605 1606 #define EFX_RXQ_SIZE(_ndescs) ((_ndescs) * sizeof (efx_qword_t)) 1607 #define EFX_RXQ_NBUFS(_ndescs) (EFX_RXQ_SIZE(_ndescs) / EFX_BUF_SIZE) 1608 #define EFX_RXQ_LIMIT(_ndescs) ((_ndescs) - 16) 1609 1610 typedef enum efx_rxq_type_e { 1611 EFX_RXQ_TYPE_DEFAULT, 1612 EFX_RXQ_TYPE_SPLIT_HEADER, 1613 EFX_RXQ_TYPE_SPLIT_PAYLOAD, 1614 EFX_RXQ_TYPE_SCATTER, 1615 EFX_RXQ_NTYPES 1616 } efx_rxq_type_t; 1617 1618 extern __checkReturn int 1619 efx_rx_qcreate( 1620 __in efx_nic_t *enp, 1621 __in unsigned int index, 1622 __in unsigned int label, 1623 __in efx_rxq_type_t type, 1624 __in efsys_mem_t *esmp, 1625 __in size_t n, 1626 __in uint32_t id, 1627 __in efx_evq_t *eep, 1628 __deref_out efx_rxq_t **erpp); 1629 1630 typedef struct efx_buffer_s { 1631 efsys_dma_addr_t eb_addr; 1632 size_t eb_size; 1633 boolean_t eb_eop; 1634 } efx_buffer_t; 1635 1636 extern void 1637 efx_rx_qpost( 1638 __in efx_rxq_t *erp, 1639 __in_ecount(n) efsys_dma_addr_t *addrp, 1640 __in size_t size, 1641 __in unsigned int n, 1642 __in unsigned int completed, 1643 __in unsigned int added); 1644 1645 extern void 1646 efx_rx_qpush( 1647 __in efx_rxq_t *erp, 1648 __in unsigned int added); 1649 1650 extern void 1651 efx_rx_qflush( 1652 __in efx_rxq_t *erp); 1653 1654 extern void 1655 efx_rx_qenable( 1656 __in efx_rxq_t *erp); 1657 1658 extern void 1659 efx_rx_qdestroy( 1660 __in efx_rxq_t *erp); 1661 1662 /* TX */ 1663 1664 typedef struct efx_txq_s efx_txq_t; 1665 1666 #if EFSYS_OPT_QSTATS 1667 1668 /* START MKCONFIG GENERATED EfxHeaderTransmitQueueBlock 536c5fa5014944bf */ 1669 typedef enum efx_tx_qstat_e { 1670 TX_POST, 1671 TX_UNALIGNED_SPLIT, 1672 TX_NQSTATS 1673 } efx_tx_qstat_t; 1674 1675 /* END MKCONFIG GENERATED EfxHeaderTransmitQueueBlock */ 1676 1677 #endif /* EFSYS_OPT_QSTATS */ 1678 1679 extern __checkReturn int 1680 efx_tx_init( 1681 __in efx_nic_t *enp); 1682 1683 extern void 1684 efx_tx_fini( 1685 __in efx_nic_t *enp); 1686 1687 #define EFX_TXQ_MAXNDESCS 4096 1688 #define EFX_TXQ_MINNDESCS 512 1689 1690 #define EFX_TXQ_NDESCS_MASK EFX_MASK(EFX_TXQ_MAXNDESCS, EFX_TXQ_MINNDESCS) 1691 1692 #define EFX_TXQ_SIZE(_ndescs) ((_ndescs) * sizeof (efx_qword_t)) 1693 #define EFX_TXQ_NBUFS(_ndescs) (EFX_TXQ_SIZE(_ndescs) / EFX_BUF_SIZE) 1694 #define EFX_TXQ_LIMIT(_ndescs) ((_ndescs) - 16) 1695 1696 extern __checkReturn int 1697 efx_tx_qcreate( 1698 __in efx_nic_t *enp, 1699 __in unsigned int index, 1700 __in unsigned int label, 1701 __in efsys_mem_t *esmp, 1702 __in size_t n, 1703 __in uint32_t id, 1704 __in uint16_t flags, 1705 __in efx_evq_t *eep, 1706 __deref_out efx_txq_t **etpp); 1707 1708 extern __checkReturn int 1709 efx_tx_qpost( 1710 __in efx_txq_t *etp, 1711 __in_ecount(n) efx_buffer_t *eb, 1712 __in unsigned int n, 1713 __in unsigned int completed, 1714 __inout unsigned int *addedp); 1715 1716 extern void 1717 efx_tx_qpush( 1718 __in efx_txq_t *etp, 1719 __in unsigned int added); 1720 1721 extern void 1722 efx_tx_qflush( 1723 __in efx_txq_t *etp); 1724 1725 extern void 1726 efx_tx_qenable( 1727 __in efx_txq_t *etp); 1728 1729 #if EFSYS_OPT_QSTATS 1730 1731 #if EFSYS_OPT_NAMES 1732 1733 extern const char __cs * 1734 efx_tx_qstat_name( 1735 __in efx_nic_t *etp, 1736 __in unsigned int id); 1737 1738 #endif /* EFSYS_OPT_NAMES */ 1739 1740 extern void 1741 efx_tx_qstats_update( 1742 __in efx_txq_t *etp, 1743 __inout_ecount(TX_NQSTATS) efsys_stat_t *stat); 1744 1745 #endif /* EFSYS_OPT_QSTATS */ 1746 1747 extern void 1748 efx_tx_qdestroy( 1749 __in efx_txq_t *etp); 1750 1751 1752 /* FILTER */ 1753 1754 #if EFSYS_OPT_FILTER 1755 1756 typedef enum efx_filter_flag_e { 1757 EFX_FILTER_FLAG_RX_RSS = 0x01, /* use RSS to spread across 1758 * multiple queues */ 1759 EFX_FILTER_FLAG_RX_SCATTER = 0x02, /* enable RX scatter */ 1760 EFX_FILTER_FLAG_RX_OVERRIDE_IP = 0x04, /* MAC filter overrides 1761 * any matching IP filter */ 1762 } efx_filter_flag_t; 1763 1764 typedef struct efx_filter_spec_s { 1765 uint8_t efs_type; 1766 uint8_t efs_flags; 1767 uint16_t efs_dmaq_id; 1768 uint32_t efs_dword[3]; 1769 } efx_filter_spec_t; 1770 1771 extern __checkReturn int 1772 efx_filter_init( 1773 __in efx_nic_t *enp); 1774 1775 extern void 1776 efx_filter_fini( 1777 __in efx_nic_t *enp); 1778 1779 extern __checkReturn int 1780 efx_rx_filter_insert( 1781 __in efx_rxq_t *erp, 1782 __inout efx_filter_spec_t *spec); 1783 1784 extern __checkReturn int 1785 efx_rx_filter_remove( 1786 __in efx_rxq_t *erp, 1787 __inout efx_filter_spec_t *spec); 1788 1789 void 1790 efx_filter_restore( 1791 __in efx_nic_t *enp); 1792 1793 extern void 1794 efx_filter_spec_rx_ipv4_tcp_full( 1795 __inout efx_filter_spec_t *spec, 1796 __in unsigned int flags, 1797 __in uint32_t src_ip, 1798 __in uint16_t src_tcp, 1799 __in uint32_t dest_ip, 1800 __in uint16_t dest_tcp); 1801 1802 extern void 1803 efx_filter_spec_rx_ipv4_tcp_wild( 1804 __inout efx_filter_spec_t *spec, 1805 __in unsigned int flags, 1806 __in uint32_t dest_ip, 1807 __in uint16_t dest_tcp); 1808 1809 extern void 1810 efx_filter_spec_rx_ipv4_udp_full( 1811 __inout efx_filter_spec_t *spec, 1812 __in unsigned int flags, 1813 __in uint32_t src_ip, 1814 __in uint16_t src_udp, 1815 __in uint32_t dest_ip, 1816 __in uint16_t dest_udp); 1817 1818 extern void 1819 efx_filter_spec_rx_ipv4_udp_wild( 1820 __inout efx_filter_spec_t *spec, 1821 __in unsigned int flags, 1822 __in uint32_t dest_ip, 1823 __in uint16_t dest_udp); 1824 1825 extern void 1826 efx_filter_spec_rx_mac_full( 1827 __inout efx_filter_spec_t *spec, 1828 __in unsigned int flags, 1829 __in uint16_t vlan_id, 1830 __in uint8_t *dest_mac); 1831 1832 extern void 1833 efx_filter_spec_rx_mac_wild( 1834 __inout efx_filter_spec_t *spec, 1835 __in unsigned int flags, 1836 __in uint8_t *dest_mac); 1837 1838 1839 extern __checkReturn int 1840 efx_tx_filter_insert( 1841 __in efx_txq_t *etp, 1842 __inout efx_filter_spec_t *spec); 1843 1844 extern __checkReturn int 1845 efx_tx_filter_remove( 1846 __in efx_txq_t *etp, 1847 __inout efx_filter_spec_t *spec); 1848 1849 extern void 1850 efx_filter_spec_tx_ipv4_tcp_full( 1851 __inout efx_filter_spec_t *spec, 1852 __in uint32_t src_ip, 1853 __in uint16_t src_tcp, 1854 __in uint32_t dest_ip, 1855 __in uint16_t dest_tcp); 1856 1857 extern void 1858 efx_filter_spec_tx_ipv4_tcp_wild( 1859 __inout efx_filter_spec_t *spec, 1860 __in uint32_t src_ip, 1861 __in uint16_t src_tcp); 1862 1863 extern void 1864 efx_filter_spec_tx_ipv4_udp_full( 1865 __inout efx_filter_spec_t *spec, 1866 __in uint32_t src_ip, 1867 __in uint16_t src_udp, 1868 __in uint32_t dest_ip, 1869 __in uint16_t dest_udp); 1870 1871 extern void 1872 efx_filter_spec_tx_ipv4_udp_wild( 1873 __inout efx_filter_spec_t *spec, 1874 __in uint32_t src_ip, 1875 __in uint16_t src_udp); 1876 1877 extern void 1878 efx_filter_spec_tx_mac_full( 1879 __inout efx_filter_spec_t *spec, 1880 __in uint16_t vlan_id, 1881 __in uint8_t *src_mac); 1882 1883 extern void 1884 efx_filter_spec_tx_mac_wild( 1885 __inout efx_filter_spec_t *spec, 1886 __in uint8_t *src_mac); 1887 1888 #endif /* EFSYS_OPT_FILTER */ 1889 1890 1891 #ifdef __cplusplus 1892 } 1893 #endif 1894 1895 #endif /* _SYS_EFX_H */ 1896