1 /****************************************************************************** 2 3 Copyright (c) 2013-2015, Intel Corporation 4 All rights reserved. 5 6 Redistribution and use in source and binary forms, with or without 7 modification, are permitted provided that the following conditions are met: 8 9 1. Redistributions of source code must retain the above copyright notice, 10 this list of conditions and the following disclaimer. 11 12 2. Redistributions in binary form must reproduce the above copyright 13 notice, this list of conditions and the following disclaimer in the 14 documentation and/or other materials provided with the distribution. 15 16 3. Neither the name of the Intel Corporation nor the names of its 17 contributors may be used to endorse or promote products derived from 18 this software without specific prior written permission. 19 20 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 21 AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 22 IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 23 ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE 24 LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 25 CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 26 SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 27 INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 28 CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 29 ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 30 POSSIBILITY OF SUCH DAMAGE. 31 32 ******************************************************************************/ 33 /*$FreeBSD$*/ 34 35 #ifndef IXL_STANDALONE_BUILD 36 #include "opt_inet.h" 37 #include "opt_inet6.h" 38 #include "opt_rss.h" 39 #endif 40 41 #include "ixl.h" 42 #include "ixl_pf.h" 43 44 #ifdef RSS 45 #include <net/rss_config.h> 46 #endif 47 48 /********************************************************************* 49 * Driver version 50 *********************************************************************/ 51 char ixl_driver_version[] = "1.4.3"; 52 53 /********************************************************************* 54 * PCI Device ID Table 55 * 56 * Used by probe to select devices to load on 57 * Last field stores an index into ixl_strings 58 * Last entry must be all 0s 59 * 60 * { Vendor ID, Device ID, SubVendor ID, SubDevice ID, String Index } 61 *********************************************************************/ 62 63 static ixl_vendor_info_t ixl_vendor_info_array[] = 64 { 65 {I40E_INTEL_VENDOR_ID, I40E_DEV_ID_SFP_XL710, 0, 0, 0}, 66 {I40E_INTEL_VENDOR_ID, I40E_DEV_ID_KX_A, 0, 0, 0}, 67 {I40E_INTEL_VENDOR_ID, I40E_DEV_ID_KX_B, 0, 0, 0}, 68 {I40E_INTEL_VENDOR_ID, I40E_DEV_ID_KX_C, 0, 0, 0}, 69 {I40E_INTEL_VENDOR_ID, I40E_DEV_ID_QSFP_A, 0, 0, 0}, 70 {I40E_INTEL_VENDOR_ID, I40E_DEV_ID_QSFP_B, 0, 0, 0}, 71 {I40E_INTEL_VENDOR_ID, I40E_DEV_ID_QSFP_C, 0, 0, 0}, 72 {I40E_INTEL_VENDOR_ID, I40E_DEV_ID_10G_BASE_T, 0, 0, 0}, 73 {I40E_INTEL_VENDOR_ID, I40E_DEV_ID_10G_BASE_T4, 0, 0, 0}, 74 {I40E_INTEL_VENDOR_ID, I40E_DEV_ID_20G_KR2, 0, 0, 0}, 75 {I40E_INTEL_VENDOR_ID, I40E_DEV_ID_20G_KR2_A, 0, 0, 0}, 76 #ifdef X722_SUPPORT 77 {I40E_INTEL_VENDOR_ID, I40E_DEV_ID_SFP_X722, 0, 0, 0}, 78 {I40E_INTEL_VENDOR_ID, I40E_DEV_ID_1G_BASE_T_X722, 0, 0, 0}, 79 {I40E_INTEL_VENDOR_ID, I40E_DEV_ID_10G_BASE_T_X722, 0, 0, 0}, 80 #endif 81 /* required last entry */ 82 {0, 0, 0, 0, 0} 83 }; 84 85 /********************************************************************* 86 * Table of branding strings 87 *********************************************************************/ 88 89 static char *ixl_strings[] = { 90 "Intel(R) Ethernet Connection XL710 Driver" 91 }; 92 93 94 /********************************************************************* 95 * Function prototypes 96 *********************************************************************/ 97 static int ixl_probe(device_t); 98 static int ixl_attach(device_t); 99 static int ixl_detach(device_t); 100 static int ixl_shutdown(device_t); 101 static int ixl_get_hw_capabilities(struct ixl_pf *); 102 static void ixl_cap_txcsum_tso(struct ixl_vsi *, struct ifnet *, int); 103 static int ixl_ioctl(struct ifnet *, u_long, caddr_t); 104 static void ixl_init(void *); 105 static void ixl_init_locked(struct ixl_pf *); 106 static void ixl_stop(struct ixl_pf *); 107 static void ixl_media_status(struct ifnet *, struct ifmediareq *); 108 static int ixl_media_change(struct ifnet *); 109 static void ixl_update_link_status(struct ixl_pf *); 110 static int ixl_allocate_pci_resources(struct ixl_pf *); 111 static u16 ixl_get_bus_info(struct i40e_hw *, device_t); 112 static int ixl_setup_stations(struct ixl_pf *); 113 static int ixl_switch_config(struct ixl_pf *); 114 static int ixl_initialize_vsi(struct ixl_vsi *); 115 static int ixl_assign_vsi_msix(struct ixl_pf *); 116 static int ixl_assign_vsi_legacy(struct ixl_pf *); 117 static int ixl_init_msix(struct ixl_pf *); 118 static void ixl_configure_msix(struct ixl_pf *); 119 static void ixl_configure_itr(struct ixl_pf *); 120 static void ixl_configure_legacy(struct ixl_pf *); 121 static void ixl_free_pci_resources(struct ixl_pf *); 122 static void ixl_local_timer(void *); 123 static int ixl_setup_interface(device_t, struct ixl_vsi *); 124 static void ixl_link_event(struct ixl_pf *, struct i40e_arq_event_info *); 125 static void ixl_config_rss(struct ixl_vsi *); 126 static void ixl_set_queue_rx_itr(struct ixl_queue *); 127 static void ixl_set_queue_tx_itr(struct ixl_queue *); 128 static int ixl_set_advertised_speeds(struct ixl_pf *, int); 129 130 static int ixl_enable_rings(struct ixl_vsi *); 131 static int ixl_disable_rings(struct ixl_vsi *); 132 static void ixl_enable_intr(struct ixl_vsi *); 133 static void ixl_disable_intr(struct ixl_vsi *); 134 static void ixl_disable_rings_intr(struct ixl_vsi *); 135 136 static void ixl_enable_adminq(struct i40e_hw *); 137 static void ixl_disable_adminq(struct i40e_hw *); 138 static void ixl_enable_queue(struct i40e_hw *, int); 139 static void ixl_disable_queue(struct i40e_hw *, int); 140 static void ixl_enable_legacy(struct i40e_hw *); 141 static void ixl_disable_legacy(struct i40e_hw *); 142 143 static void ixl_set_promisc(struct ixl_vsi *); 144 static void ixl_add_multi(struct ixl_vsi *); 145 static void ixl_del_multi(struct ixl_vsi *); 146 static void ixl_register_vlan(void *, struct ifnet *, u16); 147 static void ixl_unregister_vlan(void *, struct ifnet *, u16); 148 static void ixl_setup_vlan_filters(struct ixl_vsi *); 149 150 static void ixl_init_filters(struct ixl_vsi *); 151 static void ixl_reconfigure_filters(struct ixl_vsi *vsi); 152 static void ixl_add_filter(struct ixl_vsi *, u8 *, s16 vlan); 153 static void ixl_del_filter(struct ixl_vsi *, u8 *, s16 vlan); 154 static void ixl_add_hw_filters(struct ixl_vsi *, int, int); 155 static void ixl_del_hw_filters(struct ixl_vsi *, int); 156 static struct ixl_mac_filter * 157 ixl_find_filter(struct ixl_vsi *, u8 *, s16); 158 static void ixl_add_mc_filter(struct ixl_vsi *, u8 *); 159 static void ixl_free_mac_filters(struct ixl_vsi *vsi); 160 161 162 /* Sysctl debug interface */ 163 #ifdef IXL_DEBUG_SYSCTL 164 static int ixl_debug_info(SYSCTL_HANDLER_ARGS); 165 static void ixl_print_debug_info(struct ixl_pf *); 166 #endif 167 168 /* The MSI/X Interrupt handlers */ 169 static void ixl_intr(void *); 170 static void ixl_msix_que(void *); 171 static void ixl_msix_adminq(void *); 172 static void ixl_handle_mdd_event(struct ixl_pf *); 173 174 /* Deferred interrupt tasklets */ 175 static void ixl_do_adminq(void *, int); 176 177 /* Sysctl handlers */ 178 static int ixl_set_flowcntl(SYSCTL_HANDLER_ARGS); 179 static int ixl_set_advertise(SYSCTL_HANDLER_ARGS); 180 static int ixl_current_speed(SYSCTL_HANDLER_ARGS); 181 static int ixl_sysctl_show_fw(SYSCTL_HANDLER_ARGS); 182 183 /* Statistics */ 184 static void ixl_add_hw_stats(struct ixl_pf *); 185 static void ixl_add_sysctls_mac_stats(struct sysctl_ctx_list *, 186 struct sysctl_oid_list *, struct i40e_hw_port_stats *); 187 static void ixl_add_sysctls_eth_stats(struct sysctl_ctx_list *, 188 struct sysctl_oid_list *, 189 struct i40e_eth_stats *); 190 static void ixl_update_stats_counters(struct ixl_pf *); 191 static void ixl_update_eth_stats(struct ixl_vsi *); 192 static void ixl_update_vsi_stats(struct ixl_vsi *); 193 static void ixl_pf_reset_stats(struct ixl_pf *); 194 static void ixl_vsi_reset_stats(struct ixl_vsi *); 195 static void ixl_stat_update48(struct i40e_hw *, u32, u32, bool, 196 u64 *, u64 *); 197 static void ixl_stat_update32(struct i40e_hw *, u32, bool, 198 u64 *, u64 *); 199 200 #ifdef IXL_DEBUG_SYSCTL 201 static int ixl_sysctl_link_status(SYSCTL_HANDLER_ARGS); 202 static int ixl_sysctl_phy_abilities(SYSCTL_HANDLER_ARGS); 203 static int ixl_sysctl_sw_filter_list(SYSCTL_HANDLER_ARGS); 204 static int ixl_sysctl_hw_res_alloc(SYSCTL_HANDLER_ARGS); 205 static int ixl_sysctl_switch_config(SYSCTL_HANDLER_ARGS); 206 #endif 207 208 #ifdef PCI_IOV 209 static int ixl_adminq_err_to_errno(enum i40e_admin_queue_err err); 210 211 static int ixl_iov_init(device_t dev, uint16_t num_vfs, const nvlist_t*); 212 static void ixl_iov_uninit(device_t dev); 213 static int ixl_add_vf(device_t dev, uint16_t vfnum, const nvlist_t*); 214 215 static void ixl_handle_vf_msg(struct ixl_pf *, 216 struct i40e_arq_event_info *); 217 static void ixl_handle_vflr(void *arg, int pending); 218 219 static void ixl_reset_vf(struct ixl_pf *pf, struct ixl_vf *vf); 220 static void ixl_reinit_vf(struct ixl_pf *pf, struct ixl_vf *vf); 221 #endif 222 223 /********************************************************************* 224 * FreeBSD Device Interface Entry Points 225 *********************************************************************/ 226 227 static device_method_t ixl_methods[] = { 228 /* Device interface */ 229 DEVMETHOD(device_probe, ixl_probe), 230 DEVMETHOD(device_attach, ixl_attach), 231 DEVMETHOD(device_detach, ixl_detach), 232 DEVMETHOD(device_shutdown, ixl_shutdown), 233 #ifdef PCI_IOV 234 DEVMETHOD(pci_iov_init, ixl_iov_init), 235 DEVMETHOD(pci_iov_uninit, ixl_iov_uninit), 236 DEVMETHOD(pci_iov_add_vf, ixl_add_vf), 237 #endif 238 {0, 0} 239 }; 240 241 static driver_t ixl_driver = { 242 "ixl", ixl_methods, sizeof(struct ixl_pf), 243 }; 244 245 devclass_t ixl_devclass; 246 DRIVER_MODULE(ixl, pci, ixl_driver, ixl_devclass, 0, 0); 247 248 MODULE_DEPEND(ixl, pci, 1, 1, 1); 249 MODULE_DEPEND(ixl, ether, 1, 1, 1); 250 #ifdef DEV_NETMAP 251 MODULE_DEPEND(ixl, netmap, 1, 1, 1); 252 #endif /* DEV_NETMAP */ 253 254 /* 255 ** Global reset mutex 256 */ 257 static struct mtx ixl_reset_mtx; 258 259 /* 260 ** TUNEABLE PARAMETERS: 261 */ 262 263 static SYSCTL_NODE(_hw, OID_AUTO, ixl, CTLFLAG_RD, 0, 264 "IXL driver parameters"); 265 266 /* 267 * MSIX should be the default for best performance, 268 * but this allows it to be forced off for testing. 269 */ 270 static int ixl_enable_msix = 1; 271 TUNABLE_INT("hw.ixl.enable_msix", &ixl_enable_msix); 272 SYSCTL_INT(_hw_ixl, OID_AUTO, enable_msix, CTLFLAG_RDTUN, &ixl_enable_msix, 0, 273 "Enable MSI-X interrupts"); 274 275 /* 276 ** Number of descriptors per ring: 277 ** - TX and RX are the same size 278 */ 279 static int ixl_ringsz = DEFAULT_RING; 280 TUNABLE_INT("hw.ixl.ringsz", &ixl_ringsz); 281 SYSCTL_INT(_hw_ixl, OID_AUTO, ring_size, CTLFLAG_RDTUN, 282 &ixl_ringsz, 0, "Descriptor Ring Size"); 283 284 /* 285 ** This can be set manually, if left as 0 the 286 ** number of queues will be calculated based 287 ** on cpus and msix vectors available. 288 */ 289 int ixl_max_queues = 0; 290 TUNABLE_INT("hw.ixl.max_queues", &ixl_max_queues); 291 SYSCTL_INT(_hw_ixl, OID_AUTO, max_queues, CTLFLAG_RDTUN, 292 &ixl_max_queues, 0, "Number of Queues"); 293 294 /* 295 ** Controls for Interrupt Throttling 296 ** - true/false for dynamic adjustment 297 ** - default values for static ITR 298 */ 299 int ixl_dynamic_rx_itr = 0; 300 TUNABLE_INT("hw.ixl.dynamic_rx_itr", &ixl_dynamic_rx_itr); 301 SYSCTL_INT(_hw_ixl, OID_AUTO, dynamic_rx_itr, CTLFLAG_RDTUN, 302 &ixl_dynamic_rx_itr, 0, "Dynamic RX Interrupt Rate"); 303 304 int ixl_dynamic_tx_itr = 0; 305 TUNABLE_INT("hw.ixl.dynamic_tx_itr", &ixl_dynamic_tx_itr); 306 SYSCTL_INT(_hw_ixl, OID_AUTO, dynamic_tx_itr, CTLFLAG_RDTUN, 307 &ixl_dynamic_tx_itr, 0, "Dynamic TX Interrupt Rate"); 308 309 int ixl_rx_itr = IXL_ITR_8K; 310 TUNABLE_INT("hw.ixl.rx_itr", &ixl_rx_itr); 311 SYSCTL_INT(_hw_ixl, OID_AUTO, rx_itr, CTLFLAG_RDTUN, 312 &ixl_rx_itr, 0, "RX Interrupt Rate"); 313 314 int ixl_tx_itr = IXL_ITR_4K; 315 TUNABLE_INT("hw.ixl.tx_itr", &ixl_tx_itr); 316 SYSCTL_INT(_hw_ixl, OID_AUTO, tx_itr, CTLFLAG_RDTUN, 317 &ixl_tx_itr, 0, "TX Interrupt Rate"); 318 319 #ifdef IXL_FDIR 320 static int ixl_enable_fdir = 1; 321 TUNABLE_INT("hw.ixl.enable_fdir", &ixl_enable_fdir); 322 /* Rate at which we sample */ 323 int ixl_atr_rate = 20; 324 TUNABLE_INT("hw.ixl.atr_rate", &ixl_atr_rate); 325 #endif 326 327 #ifdef DEV_NETMAP 328 #define NETMAP_IXL_MAIN /* only bring in one part of the netmap code */ 329 #include <dev/netmap/if_ixl_netmap.h> 330 #endif /* DEV_NETMAP */ 331 332 static char *ixl_fc_string[6] = { 333 "None", 334 "Rx", 335 "Tx", 336 "Full", 337 "Priority", 338 "Default" 339 }; 340 341 static MALLOC_DEFINE(M_IXL, "ixl", "ixl driver allocations"); 342 343 static uint8_t ixl_bcast_addr[ETHER_ADDR_LEN] = 344 {0xff, 0xff, 0xff, 0xff, 0xff, 0xff}; 345 346 /********************************************************************* 347 * Device identification routine 348 * 349 * ixl_probe determines if the driver should be loaded on 350 * the hardware based on PCI vendor/device id of the device. 351 * 352 * return BUS_PROBE_DEFAULT on success, positive on failure 353 *********************************************************************/ 354 355 static int 356 ixl_probe(device_t dev) 357 { 358 ixl_vendor_info_t *ent; 359 360 u16 pci_vendor_id, pci_device_id; 361 u16 pci_subvendor_id, pci_subdevice_id; 362 char device_name[256]; 363 static bool lock_init = FALSE; 364 365 INIT_DEBUGOUT("ixl_probe: begin"); 366 367 pci_vendor_id = pci_get_vendor(dev); 368 if (pci_vendor_id != I40E_INTEL_VENDOR_ID) 369 return (ENXIO); 370 371 pci_device_id = pci_get_device(dev); 372 pci_subvendor_id = pci_get_subvendor(dev); 373 pci_subdevice_id = pci_get_subdevice(dev); 374 375 ent = ixl_vendor_info_array; 376 while (ent->vendor_id != 0) { 377 if ((pci_vendor_id == ent->vendor_id) && 378 (pci_device_id == ent->device_id) && 379 380 ((pci_subvendor_id == ent->subvendor_id) || 381 (ent->subvendor_id == 0)) && 382 383 ((pci_subdevice_id == ent->subdevice_id) || 384 (ent->subdevice_id == 0))) { 385 sprintf(device_name, "%s, Version - %s", 386 ixl_strings[ent->index], 387 ixl_driver_version); 388 device_set_desc_copy(dev, device_name); 389 /* One shot mutex init */ 390 if (lock_init == FALSE) { 391 lock_init = TRUE; 392 mtx_init(&ixl_reset_mtx, 393 "ixl_reset", 394 "IXL RESET Lock", MTX_DEF); 395 } 396 return (BUS_PROBE_DEFAULT); 397 } 398 ent++; 399 } 400 return (ENXIO); 401 } 402 403 /********************************************************************* 404 * Device initialization routine 405 * 406 * The attach entry point is called when the driver is being loaded. 407 * This routine identifies the type of hardware, allocates all resources 408 * and initializes the hardware. 409 * 410 * return 0 on success, positive on failure 411 *********************************************************************/ 412 413 static int 414 ixl_attach(device_t dev) 415 { 416 struct ixl_pf *pf; 417 struct i40e_hw *hw; 418 struct ixl_vsi *vsi; 419 u16 bus; 420 int error = 0; 421 #ifdef PCI_IOV 422 nvlist_t *pf_schema, *vf_schema; 423 int iov_error; 424 #endif 425 426 INIT_DEBUGOUT("ixl_attach: begin"); 427 428 /* Allocate, clear, and link in our primary soft structure */ 429 pf = device_get_softc(dev); 430 pf->dev = pf->osdep.dev = dev; 431 hw = &pf->hw; 432 433 /* 434 ** Note this assumes we have a single embedded VSI, 435 ** this could be enhanced later to allocate multiple 436 */ 437 vsi = &pf->vsi; 438 vsi->dev = pf->dev; 439 440 /* Core Lock Init*/ 441 IXL_PF_LOCK_INIT(pf, device_get_nameunit(dev)); 442 443 /* Set up the timer callout */ 444 callout_init_mtx(&pf->timer, &pf->pf_mtx, 0); 445 446 /* Set up sysctls */ 447 SYSCTL_ADD_PROC(device_get_sysctl_ctx(dev), 448 SYSCTL_CHILDREN(device_get_sysctl_tree(dev)), 449 OID_AUTO, "fc", CTLTYPE_INT | CTLFLAG_RW, 450 pf, 0, ixl_set_flowcntl, "I", "Flow Control"); 451 452 SYSCTL_ADD_PROC(device_get_sysctl_ctx(dev), 453 SYSCTL_CHILDREN(device_get_sysctl_tree(dev)), 454 OID_AUTO, "advertise_speed", CTLTYPE_INT | CTLFLAG_RW, 455 pf, 0, ixl_set_advertise, "I", "Advertised Speed"); 456 457 SYSCTL_ADD_PROC(device_get_sysctl_ctx(dev), 458 SYSCTL_CHILDREN(device_get_sysctl_tree(dev)), 459 OID_AUTO, "current_speed", CTLTYPE_STRING | CTLFLAG_RD, 460 pf, 0, ixl_current_speed, "A", "Current Port Speed"); 461 462 SYSCTL_ADD_PROC(device_get_sysctl_ctx(dev), 463 SYSCTL_CHILDREN(device_get_sysctl_tree(dev)), 464 OID_AUTO, "fw_version", CTLTYPE_STRING | CTLFLAG_RD, 465 pf, 0, ixl_sysctl_show_fw, "A", "Firmware version"); 466 467 SYSCTL_ADD_INT(device_get_sysctl_ctx(dev), 468 SYSCTL_CHILDREN(device_get_sysctl_tree(dev)), 469 OID_AUTO, "rx_itr", CTLFLAG_RW, 470 &ixl_rx_itr, IXL_ITR_8K, "RX ITR"); 471 472 SYSCTL_ADD_INT(device_get_sysctl_ctx(dev), 473 SYSCTL_CHILDREN(device_get_sysctl_tree(dev)), 474 OID_AUTO, "dynamic_rx_itr", CTLFLAG_RW, 475 &ixl_dynamic_rx_itr, 0, "Dynamic RX ITR"); 476 477 SYSCTL_ADD_INT(device_get_sysctl_ctx(dev), 478 SYSCTL_CHILDREN(device_get_sysctl_tree(dev)), 479 OID_AUTO, "tx_itr", CTLFLAG_RW, 480 &ixl_tx_itr, IXL_ITR_4K, "TX ITR"); 481 482 SYSCTL_ADD_INT(device_get_sysctl_ctx(dev), 483 SYSCTL_CHILDREN(device_get_sysctl_tree(dev)), 484 OID_AUTO, "dynamic_tx_itr", CTLFLAG_RW, 485 &ixl_dynamic_tx_itr, 0, "Dynamic TX ITR"); 486 487 #ifdef IXL_DEBUG_SYSCTL 488 SYSCTL_ADD_PROC(device_get_sysctl_ctx(dev), 489 SYSCTL_CHILDREN(device_get_sysctl_tree(dev)), 490 OID_AUTO, "debug", CTLTYPE_INT|CTLFLAG_RW, pf, 0, 491 ixl_debug_info, "I", "Debug Information"); 492 493 /* Debug shared-code message level */ 494 SYSCTL_ADD_UINT(device_get_sysctl_ctx(dev), 495 SYSCTL_CHILDREN(device_get_sysctl_tree(dev)), 496 OID_AUTO, "debug_mask", CTLFLAG_RW, 497 &pf->hw.debug_mask, 0, "Debug Message Level"); 498 499 SYSCTL_ADD_UINT(device_get_sysctl_ctx(dev), 500 SYSCTL_CHILDREN(device_get_sysctl_tree(dev)), 501 OID_AUTO, "vc_debug_level", CTLFLAG_RW, &pf->vc_debug_lvl, 502 0, "PF/VF Virtual Channel debug level"); 503 504 SYSCTL_ADD_PROC(device_get_sysctl_ctx(dev), 505 SYSCTL_CHILDREN(device_get_sysctl_tree(dev)), 506 OID_AUTO, "link_status", CTLTYPE_STRING | CTLFLAG_RD, 507 pf, 0, ixl_sysctl_link_status, "A", "Current Link Status"); 508 509 SYSCTL_ADD_PROC(device_get_sysctl_ctx(dev), 510 SYSCTL_CHILDREN(device_get_sysctl_tree(dev)), 511 OID_AUTO, "phy_abilities", CTLTYPE_STRING | CTLFLAG_RD, 512 pf, 0, ixl_sysctl_phy_abilities, "A", "PHY Abilities"); 513 514 SYSCTL_ADD_PROC(device_get_sysctl_ctx(dev), 515 SYSCTL_CHILDREN(device_get_sysctl_tree(dev)), 516 OID_AUTO, "filter_list", CTLTYPE_STRING | CTLFLAG_RD, 517 pf, 0, ixl_sysctl_sw_filter_list, "A", "SW Filter List"); 518 519 SYSCTL_ADD_PROC(device_get_sysctl_ctx(dev), 520 SYSCTL_CHILDREN(device_get_sysctl_tree(dev)), 521 OID_AUTO, "hw_res_alloc", CTLTYPE_STRING | CTLFLAG_RD, 522 pf, 0, ixl_sysctl_hw_res_alloc, "A", "HW Resource Allocation"); 523 524 SYSCTL_ADD_PROC(device_get_sysctl_ctx(dev), 525 SYSCTL_CHILDREN(device_get_sysctl_tree(dev)), 526 OID_AUTO, "switch_config", CTLTYPE_STRING | CTLFLAG_RD, 527 pf, 0, ixl_sysctl_switch_config, "A", "HW Switch Configuration"); 528 #endif 529 530 /* Save off the PCI information */ 531 hw->vendor_id = pci_get_vendor(dev); 532 hw->device_id = pci_get_device(dev); 533 hw->revision_id = pci_read_config(dev, PCIR_REVID, 1); 534 hw->subsystem_vendor_id = 535 pci_read_config(dev, PCIR_SUBVEND_0, 2); 536 hw->subsystem_device_id = 537 pci_read_config(dev, PCIR_SUBDEV_0, 2); 538 539 hw->bus.device = pci_get_slot(dev); 540 hw->bus.func = pci_get_function(dev); 541 542 pf->vc_debug_lvl = 1; 543 544 /* Do PCI setup - map BAR0, etc */ 545 if (ixl_allocate_pci_resources(pf)) { 546 device_printf(dev, "Allocation of PCI resources failed\n"); 547 error = ENXIO; 548 goto err_out; 549 } 550 551 /* Establish a clean starting point */ 552 i40e_clear_hw(hw); 553 error = i40e_pf_reset(hw); 554 if (error) { 555 device_printf(dev,"PF reset failure %x\n", error); 556 error = EIO; 557 goto err_out; 558 } 559 560 /* Set admin queue parameters */ 561 hw->aq.num_arq_entries = IXL_AQ_LEN; 562 hw->aq.num_asq_entries = IXL_AQ_LEN; 563 hw->aq.arq_buf_size = IXL_AQ_BUFSZ; 564 hw->aq.asq_buf_size = IXL_AQ_BUFSZ; 565 566 /* Initialize the shared code */ 567 error = i40e_init_shared_code(hw); 568 if (error) { 569 device_printf(dev,"Unable to initialize the shared code\n"); 570 error = EIO; 571 goto err_out; 572 } 573 574 /* Set up the admin queue */ 575 error = i40e_init_adminq(hw); 576 if (error) { 577 device_printf(dev, "The driver for the device stopped " 578 "because the NVM image is newer than expected.\n" 579 "You must install the most recent version of " 580 " the network driver.\n"); 581 goto err_out; 582 } 583 device_printf(dev, "%s\n", ixl_fw_version_str(hw)); 584 585 if (hw->aq.api_maj_ver == I40E_FW_API_VERSION_MAJOR && 586 hw->aq.api_min_ver > I40E_FW_API_VERSION_MINOR) 587 device_printf(dev, "The driver for the device detected " 588 "a newer version of the NVM image than expected.\n" 589 "Please install the most recent version of the network driver.\n"); 590 else if (hw->aq.api_maj_ver < I40E_FW_API_VERSION_MAJOR || 591 hw->aq.api_min_ver < (I40E_FW_API_VERSION_MINOR - 1)) 592 device_printf(dev, "The driver for the device detected " 593 "an older version of the NVM image than expected.\n" 594 "Please update the NVM image.\n"); 595 596 /* Clear PXE mode */ 597 i40e_clear_pxe_mode(hw); 598 599 /* Get capabilities from the device */ 600 error = ixl_get_hw_capabilities(pf); 601 if (error) { 602 device_printf(dev, "HW capabilities failure!\n"); 603 goto err_get_cap; 604 } 605 606 /* Set up host memory cache */ 607 error = i40e_init_lan_hmc(hw, hw->func_caps.num_tx_qp, 608 hw->func_caps.num_rx_qp, 0, 0); 609 if (error) { 610 device_printf(dev, "init_lan_hmc failed: %d\n", error); 611 goto err_get_cap; 612 } 613 614 error = i40e_configure_lan_hmc(hw, I40E_HMC_MODEL_DIRECT_ONLY); 615 if (error) { 616 device_printf(dev, "configure_lan_hmc failed: %d\n", error); 617 goto err_mac_hmc; 618 } 619 620 /* Disable LLDP from the firmware */ 621 i40e_aq_stop_lldp(hw, TRUE, NULL); 622 623 i40e_get_mac_addr(hw, hw->mac.addr); 624 error = i40e_validate_mac_addr(hw->mac.addr); 625 if (error) { 626 device_printf(dev, "validate_mac_addr failed: %d\n", error); 627 goto err_mac_hmc; 628 } 629 bcopy(hw->mac.addr, hw->mac.perm_addr, ETHER_ADDR_LEN); 630 i40e_get_port_mac_addr(hw, hw->mac.port_addr); 631 632 /* Set up VSI and queues */ 633 if (ixl_setup_stations(pf) != 0) { 634 device_printf(dev, "setup stations failed!\n"); 635 error = ENOMEM; 636 goto err_mac_hmc; 637 } 638 639 /* Initialize mac filter list for VSI */ 640 SLIST_INIT(&vsi->ftl); 641 642 /* Set up interrupt routing here */ 643 if (pf->msix > 1) 644 error = ixl_assign_vsi_msix(pf); 645 else 646 error = ixl_assign_vsi_legacy(pf); 647 if (error) 648 goto err_late; 649 650 if (((hw->aq.fw_maj_ver == 4) && (hw->aq.fw_min_ver < 33)) || 651 (hw->aq.fw_maj_ver < 4)) { 652 i40e_msec_delay(75); 653 error = i40e_aq_set_link_restart_an(hw, TRUE, NULL); 654 if (error) 655 device_printf(dev, "link restart failed, aq_err=%d\n", 656 pf->hw.aq.asq_last_status); 657 } 658 659 /* Determine link state */ 660 i40e_aq_get_link_info(hw, TRUE, NULL, NULL); 661 i40e_get_link_status(hw, &pf->link_up); 662 663 /* Setup OS specific network interface */ 664 if (ixl_setup_interface(dev, vsi) != 0) { 665 device_printf(dev, "interface setup failed!\n"); 666 error = EIO; 667 goto err_late; 668 } 669 670 error = ixl_switch_config(pf); 671 if (error) { 672 device_printf(dev, "Initial switch config failed: %d\n", error); 673 goto err_mac_hmc; 674 } 675 676 /* Limit phy interrupts to link and modules failure */ 677 error = i40e_aq_set_phy_int_mask(hw, 678 I40E_AQ_EVENT_LINK_UPDOWN | I40E_AQ_EVENT_MODULE_QUAL_FAIL, NULL); 679 if (error) 680 device_printf(dev, "set phy mask failed: %d\n", error); 681 682 /* Get the bus configuration and set the shared code */ 683 bus = ixl_get_bus_info(hw, dev); 684 i40e_set_pci_config_data(hw, bus); 685 686 /* Initialize statistics */ 687 ixl_pf_reset_stats(pf); 688 ixl_update_stats_counters(pf); 689 ixl_add_hw_stats(pf); 690 691 /* Register for VLAN events */ 692 vsi->vlan_attach = EVENTHANDLER_REGISTER(vlan_config, 693 ixl_register_vlan, vsi, EVENTHANDLER_PRI_FIRST); 694 vsi->vlan_detach = EVENTHANDLER_REGISTER(vlan_unconfig, 695 ixl_unregister_vlan, vsi, EVENTHANDLER_PRI_FIRST); 696 697 #ifdef PCI_IOV 698 /* SR-IOV is only supported when MSI-X is in use. */ 699 if (pf->msix > 1) { 700 pf_schema = pci_iov_schema_alloc_node(); 701 vf_schema = pci_iov_schema_alloc_node(); 702 pci_iov_schema_add_unicast_mac(vf_schema, "mac-addr", 0, NULL); 703 pci_iov_schema_add_bool(vf_schema, "mac-anti-spoof", 704 IOV_SCHEMA_HASDEFAULT, TRUE); 705 pci_iov_schema_add_bool(vf_schema, "allow-set-mac", 706 IOV_SCHEMA_HASDEFAULT, FALSE); 707 pci_iov_schema_add_bool(vf_schema, "allow-promisc", 708 IOV_SCHEMA_HASDEFAULT, FALSE); 709 710 iov_error = pci_iov_attach(dev, pf_schema, vf_schema); 711 if (iov_error != 0) 712 device_printf(dev, 713 "Failed to initialize SR-IOV (error=%d)\n", 714 iov_error); 715 } 716 #endif 717 718 #ifdef DEV_NETMAP 719 ixl_netmap_attach(vsi); 720 #endif /* DEV_NETMAP */ 721 INIT_DEBUGOUT("ixl_attach: end"); 722 return (0); 723 724 err_late: 725 if (vsi->ifp != NULL) 726 if_free(vsi->ifp); 727 err_mac_hmc: 728 i40e_shutdown_lan_hmc(hw); 729 err_get_cap: 730 i40e_shutdown_adminq(hw); 731 err_out: 732 ixl_free_pci_resources(pf); 733 ixl_free_vsi(vsi); 734 IXL_PF_LOCK_DESTROY(pf); 735 return (error); 736 } 737 738 /********************************************************************* 739 * Device removal routine 740 * 741 * The detach entry point is called when the driver is being removed. 742 * This routine stops the adapter and deallocates all the resources 743 * that were allocated for driver operation. 744 * 745 * return 0 on success, positive on failure 746 *********************************************************************/ 747 748 static int 749 ixl_detach(device_t dev) 750 { 751 struct ixl_pf *pf = device_get_softc(dev); 752 struct i40e_hw *hw = &pf->hw; 753 struct ixl_vsi *vsi = &pf->vsi; 754 struct ixl_queue *que = vsi->queues; 755 i40e_status status; 756 #ifdef PCI_IOV 757 int error; 758 #endif 759 760 INIT_DEBUGOUT("ixl_detach: begin"); 761 762 /* Make sure VLANS are not using driver */ 763 if (vsi->ifp->if_vlantrunk != NULL) { 764 device_printf(dev,"Vlan in use, detach first\n"); 765 return (EBUSY); 766 } 767 768 #ifdef PCI_IOV 769 error = pci_iov_detach(dev); 770 if (error != 0) { 771 device_printf(dev, "SR-IOV in use; detach first.\n"); 772 return (error); 773 } 774 #endif 775 776 ether_ifdetach(vsi->ifp); 777 if (vsi->ifp->if_drv_flags & IFF_DRV_RUNNING) { 778 IXL_PF_LOCK(pf); 779 ixl_stop(pf); 780 IXL_PF_UNLOCK(pf); 781 } 782 783 for (int i = 0; i < vsi->num_queues; i++, que++) { 784 if (que->tq) { 785 taskqueue_drain(que->tq, &que->task); 786 taskqueue_drain(que->tq, &que->tx_task); 787 taskqueue_free(que->tq); 788 } 789 } 790 791 /* Shutdown LAN HMC */ 792 status = i40e_shutdown_lan_hmc(hw); 793 if (status) 794 device_printf(dev, 795 "Shutdown LAN HMC failed with code %d\n", status); 796 797 /* Shutdown admin queue */ 798 status = i40e_shutdown_adminq(hw); 799 if (status) 800 device_printf(dev, 801 "Shutdown Admin queue failed with code %d\n", status); 802 803 /* Unregister VLAN events */ 804 if (vsi->vlan_attach != NULL) 805 EVENTHANDLER_DEREGISTER(vlan_config, vsi->vlan_attach); 806 if (vsi->vlan_detach != NULL) 807 EVENTHANDLER_DEREGISTER(vlan_unconfig, vsi->vlan_detach); 808 809 callout_drain(&pf->timer); 810 #ifdef DEV_NETMAP 811 netmap_detach(vsi->ifp); 812 #endif /* DEV_NETMAP */ 813 ixl_free_pci_resources(pf); 814 bus_generic_detach(dev); 815 if_free(vsi->ifp); 816 ixl_free_vsi(vsi); 817 IXL_PF_LOCK_DESTROY(pf); 818 return (0); 819 } 820 821 /********************************************************************* 822 * 823 * Shutdown entry point 824 * 825 **********************************************************************/ 826 827 static int 828 ixl_shutdown(device_t dev) 829 { 830 struct ixl_pf *pf = device_get_softc(dev); 831 IXL_PF_LOCK(pf); 832 ixl_stop(pf); 833 IXL_PF_UNLOCK(pf); 834 return (0); 835 } 836 837 838 /********************************************************************* 839 * 840 * Get the hardware capabilities 841 * 842 **********************************************************************/ 843 844 static int 845 ixl_get_hw_capabilities(struct ixl_pf *pf) 846 { 847 struct i40e_aqc_list_capabilities_element_resp *buf; 848 struct i40e_hw *hw = &pf->hw; 849 device_t dev = pf->dev; 850 int error, len; 851 u16 needed; 852 bool again = TRUE; 853 854 len = 40 * sizeof(struct i40e_aqc_list_capabilities_element_resp); 855 retry: 856 if (!(buf = (struct i40e_aqc_list_capabilities_element_resp *) 857 malloc(len, M_DEVBUF, M_NOWAIT | M_ZERO))) { 858 device_printf(dev, "Unable to allocate cap memory\n"); 859 return (ENOMEM); 860 } 861 862 /* This populates the hw struct */ 863 error = i40e_aq_discover_capabilities(hw, buf, len, 864 &needed, i40e_aqc_opc_list_func_capabilities, NULL); 865 free(buf, M_DEVBUF); 866 if ((pf->hw.aq.asq_last_status == I40E_AQ_RC_ENOMEM) && 867 (again == TRUE)) { 868 /* retry once with a larger buffer */ 869 again = FALSE; 870 len = needed; 871 goto retry; 872 } else if (pf->hw.aq.asq_last_status != I40E_AQ_RC_OK) { 873 device_printf(dev, "capability discovery failed: %d\n", 874 pf->hw.aq.asq_last_status); 875 return (ENODEV); 876 } 877 878 /* Capture this PF's starting queue pair */ 879 pf->qbase = hw->func_caps.base_queue; 880 881 #ifdef IXL_DEBUG 882 device_printf(dev,"pf_id=%d, num_vfs=%d, msix_pf=%d, " 883 "msix_vf=%d, fd_g=%d, fd_b=%d, tx_qp=%d rx_qp=%d qbase=%d\n", 884 hw->pf_id, hw->func_caps.num_vfs, 885 hw->func_caps.num_msix_vectors, 886 hw->func_caps.num_msix_vectors_vf, 887 hw->func_caps.fd_filters_guaranteed, 888 hw->func_caps.fd_filters_best_effort, 889 hw->func_caps.num_tx_qp, 890 hw->func_caps.num_rx_qp, 891 hw->func_caps.base_queue); 892 #endif 893 return (error); 894 } 895 896 static void 897 ixl_cap_txcsum_tso(struct ixl_vsi *vsi, struct ifnet *ifp, int mask) 898 { 899 device_t dev = vsi->dev; 900 901 /* Enable/disable TXCSUM/TSO4 */ 902 if (!(ifp->if_capenable & IFCAP_TXCSUM) 903 && !(ifp->if_capenable & IFCAP_TSO4)) { 904 if (mask & IFCAP_TXCSUM) { 905 ifp->if_capenable |= IFCAP_TXCSUM; 906 /* enable TXCSUM, restore TSO if previously enabled */ 907 if (vsi->flags & IXL_FLAGS_KEEP_TSO4) { 908 vsi->flags &= ~IXL_FLAGS_KEEP_TSO4; 909 ifp->if_capenable |= IFCAP_TSO4; 910 } 911 } 912 else if (mask & IFCAP_TSO4) { 913 ifp->if_capenable |= (IFCAP_TXCSUM | IFCAP_TSO4); 914 vsi->flags &= ~IXL_FLAGS_KEEP_TSO4; 915 device_printf(dev, 916 "TSO4 requires txcsum, enabling both...\n"); 917 } 918 } else if((ifp->if_capenable & IFCAP_TXCSUM) 919 && !(ifp->if_capenable & IFCAP_TSO4)) { 920 if (mask & IFCAP_TXCSUM) 921 ifp->if_capenable &= ~IFCAP_TXCSUM; 922 else if (mask & IFCAP_TSO4) 923 ifp->if_capenable |= IFCAP_TSO4; 924 } else if((ifp->if_capenable & IFCAP_TXCSUM) 925 && (ifp->if_capenable & IFCAP_TSO4)) { 926 if (mask & IFCAP_TXCSUM) { 927 vsi->flags |= IXL_FLAGS_KEEP_TSO4; 928 ifp->if_capenable &= ~(IFCAP_TXCSUM | IFCAP_TSO4); 929 device_printf(dev, 930 "TSO4 requires txcsum, disabling both...\n"); 931 } else if (mask & IFCAP_TSO4) 932 ifp->if_capenable &= ~IFCAP_TSO4; 933 } 934 935 /* Enable/disable TXCSUM_IPV6/TSO6 */ 936 if (!(ifp->if_capenable & IFCAP_TXCSUM_IPV6) 937 && !(ifp->if_capenable & IFCAP_TSO6)) { 938 if (mask & IFCAP_TXCSUM_IPV6) { 939 ifp->if_capenable |= IFCAP_TXCSUM_IPV6; 940 if (vsi->flags & IXL_FLAGS_KEEP_TSO6) { 941 vsi->flags &= ~IXL_FLAGS_KEEP_TSO6; 942 ifp->if_capenable |= IFCAP_TSO6; 943 } 944 } else if (mask & IFCAP_TSO6) { 945 ifp->if_capenable |= (IFCAP_TXCSUM_IPV6 | IFCAP_TSO6); 946 vsi->flags &= ~IXL_FLAGS_KEEP_TSO6; 947 device_printf(dev, 948 "TSO6 requires txcsum6, enabling both...\n"); 949 } 950 } else if((ifp->if_capenable & IFCAP_TXCSUM_IPV6) 951 && !(ifp->if_capenable & IFCAP_TSO6)) { 952 if (mask & IFCAP_TXCSUM_IPV6) 953 ifp->if_capenable &= ~IFCAP_TXCSUM_IPV6; 954 else if (mask & IFCAP_TSO6) 955 ifp->if_capenable |= IFCAP_TSO6; 956 } else if ((ifp->if_capenable & IFCAP_TXCSUM_IPV6) 957 && (ifp->if_capenable & IFCAP_TSO6)) { 958 if (mask & IFCAP_TXCSUM_IPV6) { 959 vsi->flags |= IXL_FLAGS_KEEP_TSO6; 960 ifp->if_capenable &= ~(IFCAP_TXCSUM_IPV6 | IFCAP_TSO6); 961 device_printf(dev, 962 "TSO6 requires txcsum6, disabling both...\n"); 963 } else if (mask & IFCAP_TSO6) 964 ifp->if_capenable &= ~IFCAP_TSO6; 965 } 966 } 967 968 /********************************************************************* 969 * Ioctl entry point 970 * 971 * ixl_ioctl is called when the user wants to configure the 972 * interface. 973 * 974 * return 0 on success, positive on failure 975 **********************************************************************/ 976 977 static int 978 ixl_ioctl(struct ifnet * ifp, u_long command, caddr_t data) 979 { 980 struct ixl_vsi *vsi = ifp->if_softc; 981 struct ixl_pf *pf = vsi->back; 982 struct ifreq *ifr = (struct ifreq *) data; 983 #if defined(INET) || defined(INET6) 984 struct ifaddr *ifa = (struct ifaddr *)data; 985 bool avoid_reset = FALSE; 986 #endif 987 int error = 0; 988 989 switch (command) { 990 991 case SIOCSIFADDR: 992 #ifdef INET 993 if (ifa->ifa_addr->sa_family == AF_INET) 994 avoid_reset = TRUE; 995 #endif 996 #ifdef INET6 997 if (ifa->ifa_addr->sa_family == AF_INET6) 998 avoid_reset = TRUE; 999 #endif 1000 #if defined(INET) || defined(INET6) 1001 /* 1002 ** Calling init results in link renegotiation, 1003 ** so we avoid doing it when possible. 1004 */ 1005 if (avoid_reset) { 1006 ifp->if_flags |= IFF_UP; 1007 if (!(ifp->if_drv_flags & IFF_DRV_RUNNING)) 1008 ixl_init(pf); 1009 #ifdef INET 1010 if (!(ifp->if_flags & IFF_NOARP)) 1011 arp_ifinit(ifp, ifa); 1012 #endif 1013 } else 1014 error = ether_ioctl(ifp, command, data); 1015 break; 1016 #endif 1017 case SIOCSIFMTU: 1018 IOCTL_DEBUGOUT("ioctl: SIOCSIFMTU (Set Interface MTU)"); 1019 if (ifr->ifr_mtu > IXL_MAX_FRAME - 1020 ETHER_HDR_LEN - ETHER_CRC_LEN - ETHER_VLAN_ENCAP_LEN) { 1021 error = EINVAL; 1022 } else { 1023 IXL_PF_LOCK(pf); 1024 ifp->if_mtu = ifr->ifr_mtu; 1025 vsi->max_frame_size = 1026 ifp->if_mtu + ETHER_HDR_LEN + ETHER_CRC_LEN 1027 + ETHER_VLAN_ENCAP_LEN; 1028 ixl_init_locked(pf); 1029 IXL_PF_UNLOCK(pf); 1030 } 1031 break; 1032 case SIOCSIFFLAGS: 1033 IOCTL_DEBUGOUT("ioctl: SIOCSIFFLAGS (Set Interface Flags)"); 1034 IXL_PF_LOCK(pf); 1035 if (ifp->if_flags & IFF_UP) { 1036 if ((ifp->if_drv_flags & IFF_DRV_RUNNING)) { 1037 if ((ifp->if_flags ^ pf->if_flags) & 1038 (IFF_PROMISC | IFF_ALLMULTI)) { 1039 ixl_set_promisc(vsi); 1040 } 1041 } else 1042 ixl_init_locked(pf); 1043 } else 1044 if (ifp->if_drv_flags & IFF_DRV_RUNNING) 1045 ixl_stop(pf); 1046 pf->if_flags = ifp->if_flags; 1047 IXL_PF_UNLOCK(pf); 1048 break; 1049 case SIOCADDMULTI: 1050 IOCTL_DEBUGOUT("ioctl: SIOCADDMULTI"); 1051 if (ifp->if_drv_flags & IFF_DRV_RUNNING) { 1052 IXL_PF_LOCK(pf); 1053 ixl_disable_intr(vsi); 1054 ixl_add_multi(vsi); 1055 ixl_enable_intr(vsi); 1056 IXL_PF_UNLOCK(pf); 1057 } 1058 break; 1059 case SIOCDELMULTI: 1060 IOCTL_DEBUGOUT("ioctl: SIOCDELMULTI"); 1061 if (ifp->if_drv_flags & IFF_DRV_RUNNING) { 1062 IXL_PF_LOCK(pf); 1063 ixl_disable_intr(vsi); 1064 ixl_del_multi(vsi); 1065 ixl_enable_intr(vsi); 1066 IXL_PF_UNLOCK(pf); 1067 } 1068 break; 1069 case SIOCSIFMEDIA: 1070 case SIOCGIFMEDIA: 1071 #ifdef IFM_ETH_XTYPE 1072 case SIOCGIFXMEDIA: 1073 #endif 1074 IOCTL_DEBUGOUT("ioctl: SIOCxIFMEDIA (Get/Set Interface Media)"); 1075 error = ifmedia_ioctl(ifp, ifr, &vsi->media, command); 1076 break; 1077 case SIOCSIFCAP: 1078 { 1079 int mask = ifr->ifr_reqcap ^ ifp->if_capenable; 1080 IOCTL_DEBUGOUT("ioctl: SIOCSIFCAP (Set Capabilities)"); 1081 1082 ixl_cap_txcsum_tso(vsi, ifp, mask); 1083 1084 if (mask & IFCAP_RXCSUM) 1085 ifp->if_capenable ^= IFCAP_RXCSUM; 1086 if (mask & IFCAP_RXCSUM_IPV6) 1087 ifp->if_capenable ^= IFCAP_RXCSUM_IPV6; 1088 if (mask & IFCAP_LRO) 1089 ifp->if_capenable ^= IFCAP_LRO; 1090 if (mask & IFCAP_VLAN_HWTAGGING) 1091 ifp->if_capenable ^= IFCAP_VLAN_HWTAGGING; 1092 if (mask & IFCAP_VLAN_HWFILTER) 1093 ifp->if_capenable ^= IFCAP_VLAN_HWFILTER; 1094 if (mask & IFCAP_VLAN_HWTSO) 1095 ifp->if_capenable ^= IFCAP_VLAN_HWTSO; 1096 if (ifp->if_drv_flags & IFF_DRV_RUNNING) { 1097 IXL_PF_LOCK(pf); 1098 ixl_init_locked(pf); 1099 IXL_PF_UNLOCK(pf); 1100 } 1101 VLAN_CAPABILITIES(ifp); 1102 1103 break; 1104 } 1105 1106 default: 1107 IOCTL_DEBUGOUT("ioctl: UNKNOWN (0x%X)\n", (int)command); 1108 error = ether_ioctl(ifp, command, data); 1109 break; 1110 } 1111 1112 return (error); 1113 } 1114 1115 1116 /********************************************************************* 1117 * Init entry point 1118 * 1119 * This routine is used in two ways. It is used by the stack as 1120 * init entry point in network interface structure. It is also used 1121 * by the driver as a hw/sw initialization routine to get to a 1122 * consistent state. 1123 * 1124 * return 0 on success, positive on failure 1125 **********************************************************************/ 1126 1127 static void 1128 ixl_init_locked(struct ixl_pf *pf) 1129 { 1130 struct i40e_hw *hw = &pf->hw; 1131 struct ixl_vsi *vsi = &pf->vsi; 1132 struct ifnet *ifp = vsi->ifp; 1133 device_t dev = pf->dev; 1134 struct i40e_filter_control_settings filter; 1135 u8 tmpaddr[ETHER_ADDR_LEN]; 1136 int ret; 1137 1138 mtx_assert(&pf->pf_mtx, MA_OWNED); 1139 INIT_DEBUGOUT("ixl_init: begin"); 1140 ixl_stop(pf); 1141 1142 /* Get the latest mac address... User might use a LAA */ 1143 bcopy(IF_LLADDR(vsi->ifp), tmpaddr, 1144 I40E_ETH_LENGTH_OF_ADDRESS); 1145 if (!cmp_etheraddr(hw->mac.addr, tmpaddr) && 1146 (i40e_validate_mac_addr(tmpaddr) == I40E_SUCCESS)) { 1147 ixl_del_filter(vsi, hw->mac.addr, IXL_VLAN_ANY); 1148 bcopy(tmpaddr, hw->mac.addr, 1149 I40E_ETH_LENGTH_OF_ADDRESS); 1150 ret = i40e_aq_mac_address_write(hw, 1151 I40E_AQC_WRITE_TYPE_LAA_ONLY, 1152 hw->mac.addr, NULL); 1153 if (ret) { 1154 device_printf(dev, "LLA address" 1155 "change failed!!\n"); 1156 return; 1157 } else { 1158 ixl_add_filter(vsi, hw->mac.addr, IXL_VLAN_ANY); 1159 } 1160 } 1161 1162 /* Set the various hardware offload abilities */ 1163 ifp->if_hwassist = 0; 1164 if (ifp->if_capenable & IFCAP_TSO) 1165 ifp->if_hwassist |= CSUM_TSO; 1166 if (ifp->if_capenable & IFCAP_TXCSUM) 1167 ifp->if_hwassist |= (CSUM_TCP | CSUM_UDP); 1168 if (ifp->if_capenable & IFCAP_TXCSUM_IPV6) 1169 ifp->if_hwassist |= (CSUM_TCP_IPV6 | CSUM_UDP_IPV6); 1170 1171 /* Set up the device filtering */ 1172 bzero(&filter, sizeof(filter)); 1173 filter.enable_ethtype = TRUE; 1174 filter.enable_macvlan = TRUE; 1175 #ifdef IXL_FDIR 1176 filter.enable_fdir = TRUE; 1177 #endif 1178 if (i40e_set_filter_control(hw, &filter)) 1179 device_printf(dev, "set_filter_control() failed\n"); 1180 1181 /* Set up RSS */ 1182 ixl_config_rss(vsi); 1183 1184 /* 1185 ** Prepare the VSI: rings, hmc contexts, etc... 1186 */ 1187 if (ixl_initialize_vsi(vsi)) { 1188 device_printf(dev, "initialize vsi failed!!\n"); 1189 return; 1190 } 1191 1192 /* Add protocol filters to list */ 1193 ixl_init_filters(vsi); 1194 1195 /* Setup vlan's if needed */ 1196 ixl_setup_vlan_filters(vsi); 1197 1198 /* Start the local timer */ 1199 callout_reset(&pf->timer, hz, ixl_local_timer, pf); 1200 1201 /* Set up MSI/X routing and the ITR settings */ 1202 if (ixl_enable_msix) { 1203 ixl_configure_msix(pf); 1204 ixl_configure_itr(pf); 1205 } else 1206 ixl_configure_legacy(pf); 1207 1208 ixl_enable_rings(vsi); 1209 1210 i40e_aq_set_default_vsi(hw, vsi->seid, NULL); 1211 1212 ixl_reconfigure_filters(vsi); 1213 1214 /* Set MTU in hardware*/ 1215 int aq_error = i40e_aq_set_mac_config(hw, vsi->max_frame_size, 1216 TRUE, 0, NULL); 1217 if (aq_error) 1218 device_printf(vsi->dev, 1219 "aq_set_mac_config in init error, code %d\n", 1220 aq_error); 1221 1222 /* And now turn on interrupts */ 1223 ixl_enable_intr(vsi); 1224 1225 /* Now inform the stack we're ready */ 1226 ifp->if_drv_flags |= IFF_DRV_RUNNING; 1227 ifp->if_drv_flags &= ~IFF_DRV_OACTIVE; 1228 1229 return; 1230 } 1231 1232 static void 1233 ixl_init(void *arg) 1234 { 1235 struct ixl_pf *pf = arg; 1236 1237 IXL_PF_LOCK(pf); 1238 ixl_init_locked(pf); 1239 IXL_PF_UNLOCK(pf); 1240 return; 1241 } 1242 1243 /* 1244 ** 1245 ** MSIX Interrupt Handlers and Tasklets 1246 ** 1247 */ 1248 static void 1249 ixl_handle_que(void *context, int pending) 1250 { 1251 struct ixl_queue *que = context; 1252 struct ixl_vsi *vsi = que->vsi; 1253 struct i40e_hw *hw = vsi->hw; 1254 struct tx_ring *txr = &que->txr; 1255 struct ifnet *ifp = vsi->ifp; 1256 bool more; 1257 1258 if (ifp->if_drv_flags & IFF_DRV_RUNNING) { 1259 more = ixl_rxeof(que, IXL_RX_LIMIT); 1260 IXL_TX_LOCK(txr); 1261 ixl_txeof(que); 1262 if (!drbr_empty(ifp, txr->br)) 1263 ixl_mq_start_locked(ifp, txr); 1264 IXL_TX_UNLOCK(txr); 1265 if (more) { 1266 taskqueue_enqueue(que->tq, &que->task); 1267 return; 1268 } 1269 } 1270 1271 /* Reenable this interrupt - hmmm */ 1272 ixl_enable_queue(hw, que->me); 1273 return; 1274 } 1275 1276 1277 /********************************************************************* 1278 * 1279 * Legacy Interrupt Service routine 1280 * 1281 **********************************************************************/ 1282 void 1283 ixl_intr(void *arg) 1284 { 1285 struct ixl_pf *pf = arg; 1286 struct i40e_hw *hw = &pf->hw; 1287 struct ixl_vsi *vsi = &pf->vsi; 1288 struct ixl_queue *que = vsi->queues; 1289 struct ifnet *ifp = vsi->ifp; 1290 struct tx_ring *txr = &que->txr; 1291 u32 reg, icr0, mask; 1292 bool more_tx, more_rx; 1293 1294 ++que->irqs; 1295 1296 /* Protect against spurious interrupts */ 1297 if ((ifp->if_drv_flags & IFF_DRV_RUNNING) == 0) 1298 return; 1299 1300 icr0 = rd32(hw, I40E_PFINT_ICR0); 1301 1302 reg = rd32(hw, I40E_PFINT_DYN_CTL0); 1303 reg = reg | I40E_PFINT_DYN_CTL0_CLEARPBA_MASK; 1304 wr32(hw, I40E_PFINT_DYN_CTL0, reg); 1305 1306 mask = rd32(hw, I40E_PFINT_ICR0_ENA); 1307 1308 #ifdef PCI_IOV 1309 if (icr0 & I40E_PFINT_ICR0_VFLR_MASK) 1310 taskqueue_enqueue(pf->tq, &pf->vflr_task); 1311 #endif 1312 1313 if (icr0 & I40E_PFINT_ICR0_ADMINQ_MASK) { 1314 taskqueue_enqueue(pf->tq, &pf->adminq); 1315 return; 1316 } 1317 1318 more_rx = ixl_rxeof(que, IXL_RX_LIMIT); 1319 1320 IXL_TX_LOCK(txr); 1321 more_tx = ixl_txeof(que); 1322 if (!drbr_empty(vsi->ifp, txr->br)) 1323 more_tx = 1; 1324 IXL_TX_UNLOCK(txr); 1325 1326 /* re-enable other interrupt causes */ 1327 wr32(hw, I40E_PFINT_ICR0_ENA, mask); 1328 1329 /* And now the queues */ 1330 reg = rd32(hw, I40E_QINT_RQCTL(0)); 1331 reg |= I40E_QINT_RQCTL_CAUSE_ENA_MASK; 1332 wr32(hw, I40E_QINT_RQCTL(0), reg); 1333 1334 reg = rd32(hw, I40E_QINT_TQCTL(0)); 1335 reg |= I40E_QINT_TQCTL_CAUSE_ENA_MASK; 1336 reg &= ~I40E_PFINT_ICR0_INTEVENT_MASK; 1337 wr32(hw, I40E_QINT_TQCTL(0), reg); 1338 1339 ixl_enable_legacy(hw); 1340 1341 return; 1342 } 1343 1344 1345 /********************************************************************* 1346 * 1347 * MSIX VSI Interrupt Service routine 1348 * 1349 **********************************************************************/ 1350 void 1351 ixl_msix_que(void *arg) 1352 { 1353 struct ixl_queue *que = arg; 1354 struct ixl_vsi *vsi = que->vsi; 1355 struct i40e_hw *hw = vsi->hw; 1356 struct tx_ring *txr = &que->txr; 1357 bool more_tx, more_rx; 1358 1359 /* Protect against spurious interrupts */ 1360 if (!(vsi->ifp->if_drv_flags & IFF_DRV_RUNNING)) 1361 return; 1362 1363 ++que->irqs; 1364 1365 more_rx = ixl_rxeof(que, IXL_RX_LIMIT); 1366 1367 IXL_TX_LOCK(txr); 1368 more_tx = ixl_txeof(que); 1369 /* 1370 ** Make certain that if the stack 1371 ** has anything queued the task gets 1372 ** scheduled to handle it. 1373 */ 1374 if (!drbr_empty(vsi->ifp, txr->br)) 1375 more_tx = 1; 1376 IXL_TX_UNLOCK(txr); 1377 1378 ixl_set_queue_rx_itr(que); 1379 ixl_set_queue_tx_itr(que); 1380 1381 if (more_tx || more_rx) 1382 taskqueue_enqueue(que->tq, &que->task); 1383 else 1384 ixl_enable_queue(hw, que->me); 1385 1386 return; 1387 } 1388 1389 1390 /********************************************************************* 1391 * 1392 * MSIX Admin Queue Interrupt Service routine 1393 * 1394 **********************************************************************/ 1395 static void 1396 ixl_msix_adminq(void *arg) 1397 { 1398 struct ixl_pf *pf = arg; 1399 struct i40e_hw *hw = &pf->hw; 1400 u32 reg, mask; 1401 1402 ++pf->admin_irq; 1403 1404 reg = rd32(hw, I40E_PFINT_ICR0); 1405 mask = rd32(hw, I40E_PFINT_ICR0_ENA); 1406 1407 /* Check on the cause */ 1408 if (reg & I40E_PFINT_ICR0_ADMINQ_MASK) 1409 mask &= ~I40E_PFINT_ICR0_ENA_ADMINQ_MASK; 1410 1411 if (reg & I40E_PFINT_ICR0_MAL_DETECT_MASK) { 1412 ixl_handle_mdd_event(pf); 1413 mask &= ~I40E_PFINT_ICR0_ENA_MAL_DETECT_MASK; 1414 } 1415 1416 #ifdef PCI_IOV 1417 if (reg & I40E_PFINT_ICR0_VFLR_MASK) { 1418 mask &= ~I40E_PFINT_ICR0_ENA_VFLR_MASK; 1419 taskqueue_enqueue(pf->tq, &pf->vflr_task); 1420 } 1421 #endif 1422 1423 reg = rd32(hw, I40E_PFINT_DYN_CTL0); 1424 reg = reg | I40E_PFINT_DYN_CTL0_CLEARPBA_MASK; 1425 wr32(hw, I40E_PFINT_DYN_CTL0, reg); 1426 1427 taskqueue_enqueue(pf->tq, &pf->adminq); 1428 return; 1429 } 1430 1431 /********************************************************************* 1432 * 1433 * Media Ioctl callback 1434 * 1435 * This routine is called whenever the user queries the status of 1436 * the interface using ifconfig. 1437 * 1438 **********************************************************************/ 1439 static void 1440 ixl_media_status(struct ifnet * ifp, struct ifmediareq * ifmr) 1441 { 1442 struct ixl_vsi *vsi = ifp->if_softc; 1443 struct ixl_pf *pf = vsi->back; 1444 struct i40e_hw *hw = &pf->hw; 1445 1446 INIT_DEBUGOUT("ixl_media_status: begin"); 1447 IXL_PF_LOCK(pf); 1448 1449 hw->phy.get_link_info = TRUE; 1450 i40e_get_link_status(hw, &pf->link_up); 1451 ixl_update_link_status(pf); 1452 1453 ifmr->ifm_status = IFM_AVALID; 1454 ifmr->ifm_active = IFM_ETHER; 1455 1456 if (!pf->link_up) { 1457 IXL_PF_UNLOCK(pf); 1458 return; 1459 } 1460 1461 ifmr->ifm_status |= IFM_ACTIVE; 1462 /* Hardware is always full-duplex */ 1463 ifmr->ifm_active |= IFM_FDX; 1464 1465 switch (hw->phy.link_info.phy_type) { 1466 /* 100 M */ 1467 case I40E_PHY_TYPE_100BASE_TX: 1468 ifmr->ifm_active |= IFM_100_TX; 1469 break; 1470 /* 1 G */ 1471 case I40E_PHY_TYPE_1000BASE_T: 1472 ifmr->ifm_active |= IFM_1000_T; 1473 break; 1474 case I40E_PHY_TYPE_1000BASE_SX: 1475 ifmr->ifm_active |= IFM_1000_SX; 1476 break; 1477 case I40E_PHY_TYPE_1000BASE_LX: 1478 ifmr->ifm_active |= IFM_1000_LX; 1479 break; 1480 /* 10 G */ 1481 case I40E_PHY_TYPE_10GBASE_SFPP_CU: 1482 ifmr->ifm_active |= IFM_10G_TWINAX; 1483 break; 1484 case I40E_PHY_TYPE_10GBASE_SR: 1485 ifmr->ifm_active |= IFM_10G_SR; 1486 break; 1487 case I40E_PHY_TYPE_10GBASE_LR: 1488 ifmr->ifm_active |= IFM_10G_LR; 1489 break; 1490 case I40E_PHY_TYPE_10GBASE_T: 1491 ifmr->ifm_active |= IFM_10G_T; 1492 break; 1493 /* 40 G */ 1494 case I40E_PHY_TYPE_40GBASE_CR4: 1495 case I40E_PHY_TYPE_40GBASE_CR4_CU: 1496 ifmr->ifm_active |= IFM_40G_CR4; 1497 break; 1498 case I40E_PHY_TYPE_40GBASE_SR4: 1499 ifmr->ifm_active |= IFM_40G_SR4; 1500 break; 1501 case I40E_PHY_TYPE_40GBASE_LR4: 1502 ifmr->ifm_active |= IFM_40G_LR4; 1503 break; 1504 #ifndef IFM_ETH_XTYPE 1505 case I40E_PHY_TYPE_1000BASE_KX: 1506 ifmr->ifm_active |= IFM_1000_CX; 1507 break; 1508 case I40E_PHY_TYPE_10GBASE_CR1_CU: 1509 case I40E_PHY_TYPE_10GBASE_CR1: 1510 ifmr->ifm_active |= IFM_10G_TWINAX; 1511 break; 1512 case I40E_PHY_TYPE_10GBASE_KX4: 1513 ifmr->ifm_active |= IFM_10G_CX4; 1514 break; 1515 case I40E_PHY_TYPE_10GBASE_KR: 1516 ifmr->ifm_active |= IFM_10G_SR; 1517 break; 1518 case I40E_PHY_TYPE_40GBASE_KR4: 1519 case I40E_PHY_TYPE_XLPPI: 1520 ifmr->ifm_active |= IFM_40G_SR4; 1521 break; 1522 #else 1523 case I40E_PHY_TYPE_1000BASE_KX: 1524 ifmr->ifm_active |= IFM_1000_KX; 1525 break; 1526 /* ERJ: What's the difference between these? */ 1527 case I40E_PHY_TYPE_10GBASE_CR1_CU: 1528 case I40E_PHY_TYPE_10GBASE_CR1: 1529 ifmr->ifm_active |= IFM_10G_CR1; 1530 break; 1531 case I40E_PHY_TYPE_10GBASE_KX4: 1532 ifmr->ifm_active |= IFM_10G_KX4; 1533 break; 1534 case I40E_PHY_TYPE_10GBASE_KR: 1535 ifmr->ifm_active |= IFM_10G_KR; 1536 break; 1537 case I40E_PHY_TYPE_20GBASE_KR2: 1538 ifmr->ifm_active |= IFM_20G_KR2; 1539 break; 1540 case I40E_PHY_TYPE_40GBASE_KR4: 1541 ifmr->ifm_active |= IFM_40G_KR4; 1542 break; 1543 case I40E_PHY_TYPE_XLPPI: 1544 ifmr->ifm_active |= IFM_40G_XLPPI; 1545 break; 1546 #endif 1547 default: 1548 ifmr->ifm_active |= IFM_UNKNOWN; 1549 break; 1550 } 1551 /* Report flow control status as well */ 1552 if (hw->phy.link_info.an_info & I40E_AQ_LINK_PAUSE_TX) 1553 ifmr->ifm_active |= IFM_ETH_TXPAUSE; 1554 if (hw->phy.link_info.an_info & I40E_AQ_LINK_PAUSE_RX) 1555 ifmr->ifm_active |= IFM_ETH_RXPAUSE; 1556 1557 IXL_PF_UNLOCK(pf); 1558 1559 return; 1560 } 1561 1562 /********************************************************************* 1563 * 1564 * Media Ioctl callback 1565 * 1566 * This routine is called when the user changes speed/duplex using 1567 * media/mediopt option with ifconfig. 1568 * 1569 **********************************************************************/ 1570 static int 1571 ixl_media_change(struct ifnet * ifp) 1572 { 1573 struct ixl_vsi *vsi = ifp->if_softc; 1574 struct ifmedia *ifm = &vsi->media; 1575 1576 INIT_DEBUGOUT("ixl_media_change: begin"); 1577 1578 if (IFM_TYPE(ifm->ifm_media) != IFM_ETHER) 1579 return (EINVAL); 1580 1581 if_printf(ifp, "Media change is currently not supported.\n"); 1582 1583 return (ENODEV); 1584 } 1585 1586 1587 #ifdef IXL_FDIR 1588 /* 1589 ** ATR: Application Targetted Receive - creates a filter 1590 ** based on TX flow info that will keep the receive 1591 ** portion of the flow on the same queue. Based on the 1592 ** implementation this is only available for TCP connections 1593 */ 1594 void 1595 ixl_atr(struct ixl_queue *que, struct tcphdr *th, int etype) 1596 { 1597 struct ixl_vsi *vsi = que->vsi; 1598 struct tx_ring *txr = &que->txr; 1599 struct i40e_filter_program_desc *FDIR; 1600 u32 ptype, dtype; 1601 int idx; 1602 1603 /* check if ATR is enabled and sample rate */ 1604 if ((!ixl_enable_fdir) || (!txr->atr_rate)) 1605 return; 1606 /* 1607 ** We sample all TCP SYN/FIN packets, 1608 ** or at the selected sample rate 1609 */ 1610 txr->atr_count++; 1611 if (((th->th_flags & (TH_FIN | TH_SYN)) == 0) && 1612 (txr->atr_count < txr->atr_rate)) 1613 return; 1614 txr->atr_count = 0; 1615 1616 /* Get a descriptor to use */ 1617 idx = txr->next_avail; 1618 FDIR = (struct i40e_filter_program_desc *) &txr->base[idx]; 1619 if (++idx == que->num_desc) 1620 idx = 0; 1621 txr->avail--; 1622 txr->next_avail = idx; 1623 1624 ptype = (que->me << I40E_TXD_FLTR_QW0_QINDEX_SHIFT) & 1625 I40E_TXD_FLTR_QW0_QINDEX_MASK; 1626 1627 ptype |= (etype == ETHERTYPE_IP) ? 1628 (I40E_FILTER_PCTYPE_NONF_IPV4_TCP << 1629 I40E_TXD_FLTR_QW0_PCTYPE_SHIFT) : 1630 (I40E_FILTER_PCTYPE_NONF_IPV6_TCP << 1631 I40E_TXD_FLTR_QW0_PCTYPE_SHIFT); 1632 1633 ptype |= vsi->id << I40E_TXD_FLTR_QW0_DEST_VSI_SHIFT; 1634 1635 dtype = I40E_TX_DESC_DTYPE_FILTER_PROG; 1636 1637 /* 1638 ** We use the TCP TH_FIN as a trigger to remove 1639 ** the filter, otherwise its an update. 1640 */ 1641 dtype |= (th->th_flags & TH_FIN) ? 1642 (I40E_FILTER_PROGRAM_DESC_PCMD_REMOVE << 1643 I40E_TXD_FLTR_QW1_PCMD_SHIFT) : 1644 (I40E_FILTER_PROGRAM_DESC_PCMD_ADD_UPDATE << 1645 I40E_TXD_FLTR_QW1_PCMD_SHIFT); 1646 1647 dtype |= I40E_FILTER_PROGRAM_DESC_DEST_DIRECT_PACKET_QINDEX << 1648 I40E_TXD_FLTR_QW1_DEST_SHIFT; 1649 1650 dtype |= I40E_FILTER_PROGRAM_DESC_FD_STATUS_FD_ID << 1651 I40E_TXD_FLTR_QW1_FD_STATUS_SHIFT; 1652 1653 FDIR->qindex_flex_ptype_vsi = htole32(ptype); 1654 FDIR->dtype_cmd_cntindex = htole32(dtype); 1655 return; 1656 } 1657 #endif 1658 1659 1660 static void 1661 ixl_set_promisc(struct ixl_vsi *vsi) 1662 { 1663 struct ifnet *ifp = vsi->ifp; 1664 struct i40e_hw *hw = vsi->hw; 1665 int err, mcnt = 0; 1666 bool uni = FALSE, multi = FALSE; 1667 1668 if (ifp->if_flags & IFF_ALLMULTI) 1669 multi = TRUE; 1670 else { /* Need to count the multicast addresses */ 1671 struct ifmultiaddr *ifma; 1672 if_maddr_rlock(ifp); 1673 TAILQ_FOREACH(ifma, &ifp->if_multiaddrs, ifma_link) { 1674 if (ifma->ifma_addr->sa_family != AF_LINK) 1675 continue; 1676 if (mcnt == MAX_MULTICAST_ADDR) 1677 break; 1678 mcnt++; 1679 } 1680 if_maddr_runlock(ifp); 1681 } 1682 1683 if (mcnt >= MAX_MULTICAST_ADDR) 1684 multi = TRUE; 1685 if (ifp->if_flags & IFF_PROMISC) 1686 uni = TRUE; 1687 1688 err = i40e_aq_set_vsi_unicast_promiscuous(hw, 1689 vsi->seid, uni, NULL); 1690 err = i40e_aq_set_vsi_multicast_promiscuous(hw, 1691 vsi->seid, multi, NULL); 1692 return; 1693 } 1694 1695 /********************************************************************* 1696 * Filter Routines 1697 * 1698 * Routines for multicast and vlan filter management. 1699 * 1700 *********************************************************************/ 1701 static void 1702 ixl_add_multi(struct ixl_vsi *vsi) 1703 { 1704 struct ifmultiaddr *ifma; 1705 struct ifnet *ifp = vsi->ifp; 1706 struct i40e_hw *hw = vsi->hw; 1707 int mcnt = 0, flags; 1708 1709 IOCTL_DEBUGOUT("ixl_add_multi: begin"); 1710 1711 if_maddr_rlock(ifp); 1712 /* 1713 ** First just get a count, to decide if we 1714 ** we simply use multicast promiscuous. 1715 */ 1716 TAILQ_FOREACH(ifma, &ifp->if_multiaddrs, ifma_link) { 1717 if (ifma->ifma_addr->sa_family != AF_LINK) 1718 continue; 1719 mcnt++; 1720 } 1721 if_maddr_runlock(ifp); 1722 1723 if (__predict_false(mcnt >= MAX_MULTICAST_ADDR)) { 1724 /* delete existing MC filters */ 1725 ixl_del_hw_filters(vsi, mcnt); 1726 i40e_aq_set_vsi_multicast_promiscuous(hw, 1727 vsi->seid, TRUE, NULL); 1728 return; 1729 } 1730 1731 mcnt = 0; 1732 if_maddr_rlock(ifp); 1733 TAILQ_FOREACH(ifma, &ifp->if_multiaddrs, ifma_link) { 1734 if (ifma->ifma_addr->sa_family != AF_LINK) 1735 continue; 1736 ixl_add_mc_filter(vsi, 1737 (u8*)LLADDR((struct sockaddr_dl *) ifma->ifma_addr)); 1738 mcnt++; 1739 } 1740 if_maddr_runlock(ifp); 1741 if (mcnt > 0) { 1742 flags = (IXL_FILTER_ADD | IXL_FILTER_USED | IXL_FILTER_MC); 1743 ixl_add_hw_filters(vsi, flags, mcnt); 1744 } 1745 1746 IOCTL_DEBUGOUT("ixl_add_multi: end"); 1747 return; 1748 } 1749 1750 static void 1751 ixl_del_multi(struct ixl_vsi *vsi) 1752 { 1753 struct ifnet *ifp = vsi->ifp; 1754 struct ifmultiaddr *ifma; 1755 struct ixl_mac_filter *f; 1756 int mcnt = 0; 1757 bool match = FALSE; 1758 1759 IOCTL_DEBUGOUT("ixl_del_multi: begin"); 1760 1761 /* Search for removed multicast addresses */ 1762 if_maddr_rlock(ifp); 1763 SLIST_FOREACH(f, &vsi->ftl, next) { 1764 if ((f->flags & IXL_FILTER_USED) && (f->flags & IXL_FILTER_MC)) { 1765 match = FALSE; 1766 TAILQ_FOREACH(ifma, &ifp->if_multiaddrs, ifma_link) { 1767 if (ifma->ifma_addr->sa_family != AF_LINK) 1768 continue; 1769 u8 *mc_addr = (u8 *)LLADDR((struct sockaddr_dl *)ifma->ifma_addr); 1770 if (cmp_etheraddr(f->macaddr, mc_addr)) { 1771 match = TRUE; 1772 break; 1773 } 1774 } 1775 if (match == FALSE) { 1776 f->flags |= IXL_FILTER_DEL; 1777 mcnt++; 1778 } 1779 } 1780 } 1781 if_maddr_runlock(ifp); 1782 1783 if (mcnt > 0) 1784 ixl_del_hw_filters(vsi, mcnt); 1785 } 1786 1787 1788 /********************************************************************* 1789 * Timer routine 1790 * 1791 * This routine checks for link status,updates statistics, 1792 * and runs the watchdog check. 1793 * 1794 **********************************************************************/ 1795 1796 static void 1797 ixl_local_timer(void *arg) 1798 { 1799 struct ixl_pf *pf = arg; 1800 struct i40e_hw *hw = &pf->hw; 1801 struct ixl_vsi *vsi = &pf->vsi; 1802 struct ixl_queue *que = vsi->queues; 1803 device_t dev = pf->dev; 1804 int hung = 0; 1805 u32 mask; 1806 1807 mtx_assert(&pf->pf_mtx, MA_OWNED); 1808 1809 /* Fire off the adminq task */ 1810 taskqueue_enqueue(pf->tq, &pf->adminq); 1811 1812 /* Update stats */ 1813 ixl_update_stats_counters(pf); 1814 1815 /* 1816 ** Check status of the queues 1817 */ 1818 mask = (I40E_PFINT_DYN_CTLN_INTENA_MASK | 1819 I40E_PFINT_DYN_CTLN_SWINT_TRIG_MASK); 1820 1821 for (int i = 0; i < vsi->num_queues; i++,que++) { 1822 /* Any queues with outstanding work get a sw irq */ 1823 if (que->busy) 1824 wr32(hw, I40E_PFINT_DYN_CTLN(que->me), mask); 1825 /* 1826 ** Each time txeof runs without cleaning, but there 1827 ** are uncleaned descriptors it increments busy. If 1828 ** we get to 5 we declare it hung. 1829 */ 1830 if (que->busy == IXL_QUEUE_HUNG) { 1831 ++hung; 1832 /* Mark the queue as inactive */ 1833 vsi->active_queues &= ~((u64)1 << que->me); 1834 continue; 1835 } else { 1836 /* Check if we've come back from hung */ 1837 if ((vsi->active_queues & ((u64)1 << que->me)) == 0) 1838 vsi->active_queues |= ((u64)1 << que->me); 1839 } 1840 if (que->busy >= IXL_MAX_TX_BUSY) { 1841 #ifdef IXL_DEBUG 1842 device_printf(dev,"Warning queue %d " 1843 "appears to be hung!\n", i); 1844 #endif 1845 que->busy = IXL_QUEUE_HUNG; 1846 ++hung; 1847 } 1848 } 1849 /* Only reinit if all queues show hung */ 1850 if (hung == vsi->num_queues) 1851 goto hung; 1852 1853 callout_reset(&pf->timer, hz, ixl_local_timer, pf); 1854 return; 1855 1856 hung: 1857 device_printf(dev, "Local Timer: HANG DETECT - Resetting!!\n"); 1858 ixl_init_locked(pf); 1859 } 1860 1861 /* 1862 ** Note: this routine updates the OS on the link state 1863 ** the real check of the hardware only happens with 1864 ** a link interrupt. 1865 */ 1866 static void 1867 ixl_update_link_status(struct ixl_pf *pf) 1868 { 1869 struct ixl_vsi *vsi = &pf->vsi; 1870 struct i40e_hw *hw = &pf->hw; 1871 struct ifnet *ifp = vsi->ifp; 1872 device_t dev = pf->dev; 1873 1874 if (pf->link_up){ 1875 if (vsi->link_active == FALSE) { 1876 pf->fc = hw->fc.current_mode; 1877 if (bootverbose) { 1878 device_printf(dev,"Link is up %d Gbps %s," 1879 " Flow Control: %s\n", 1880 ((pf->link_speed == 1881 I40E_LINK_SPEED_40GB)? 40:10), 1882 "Full Duplex", ixl_fc_string[pf->fc]); 1883 } 1884 vsi->link_active = TRUE; 1885 /* 1886 ** Warn user if link speed on NPAR enabled 1887 ** partition is not at least 10GB 1888 */ 1889 if (hw->func_caps.npar_enable && 1890 (hw->phy.link_info.link_speed == 1891 I40E_LINK_SPEED_1GB || 1892 hw->phy.link_info.link_speed == 1893 I40E_LINK_SPEED_100MB)) 1894 device_printf(dev, "The partition detected" 1895 "link speed that is less than 10Gbps\n"); 1896 if_link_state_change(ifp, LINK_STATE_UP); 1897 } 1898 } else { /* Link down */ 1899 if (vsi->link_active == TRUE) { 1900 if (bootverbose) 1901 device_printf(dev,"Link is Down\n"); 1902 if_link_state_change(ifp, LINK_STATE_DOWN); 1903 vsi->link_active = FALSE; 1904 } 1905 } 1906 1907 return; 1908 } 1909 1910 /********************************************************************* 1911 * 1912 * This routine disables all traffic on the adapter by issuing a 1913 * global reset on the MAC and deallocates TX/RX buffers. 1914 * 1915 **********************************************************************/ 1916 1917 static void 1918 ixl_stop(struct ixl_pf *pf) 1919 { 1920 struct ixl_vsi *vsi = &pf->vsi; 1921 struct ifnet *ifp = vsi->ifp; 1922 1923 mtx_assert(&pf->pf_mtx, MA_OWNED); 1924 1925 INIT_DEBUGOUT("ixl_stop: begin\n"); 1926 if (pf->num_vfs == 0) 1927 ixl_disable_intr(vsi); 1928 else 1929 ixl_disable_rings_intr(vsi); 1930 ixl_disable_rings(vsi); 1931 1932 /* Tell the stack that the interface is no longer active */ 1933 ifp->if_drv_flags &= ~(IFF_DRV_RUNNING | IFF_DRV_OACTIVE); 1934 1935 /* Stop the local timer */ 1936 callout_stop(&pf->timer); 1937 1938 return; 1939 } 1940 1941 1942 /********************************************************************* 1943 * 1944 * Setup MSIX Interrupt resources and handlers for the VSI 1945 * 1946 **********************************************************************/ 1947 static int 1948 ixl_assign_vsi_legacy(struct ixl_pf *pf) 1949 { 1950 device_t dev = pf->dev; 1951 struct ixl_vsi *vsi = &pf->vsi; 1952 struct ixl_queue *que = vsi->queues; 1953 int error, rid = 0; 1954 1955 if (pf->msix == 1) 1956 rid = 1; 1957 pf->res = bus_alloc_resource_any(dev, SYS_RES_IRQ, 1958 &rid, RF_SHAREABLE | RF_ACTIVE); 1959 if (pf->res == NULL) { 1960 device_printf(dev,"Unable to allocate" 1961 " bus resource: vsi legacy/msi interrupt\n"); 1962 return (ENXIO); 1963 } 1964 1965 /* Set the handler function */ 1966 error = bus_setup_intr(dev, pf->res, 1967 INTR_TYPE_NET | INTR_MPSAFE, NULL, 1968 ixl_intr, pf, &pf->tag); 1969 if (error) { 1970 pf->res = NULL; 1971 device_printf(dev, "Failed to register legacy/msi handler"); 1972 return (error); 1973 } 1974 bus_describe_intr(dev, pf->res, pf->tag, "irq0"); 1975 TASK_INIT(&que->tx_task, 0, ixl_deferred_mq_start, que); 1976 TASK_INIT(&que->task, 0, ixl_handle_que, que); 1977 que->tq = taskqueue_create_fast("ixl_que", M_NOWAIT, 1978 taskqueue_thread_enqueue, &que->tq); 1979 taskqueue_start_threads(&que->tq, 1, PI_NET, "%s que", 1980 device_get_nameunit(dev)); 1981 TASK_INIT(&pf->adminq, 0, ixl_do_adminq, pf); 1982 1983 #ifdef PCI_IOV 1984 TASK_INIT(&pf->vflr_task, 0, ixl_handle_vflr, pf); 1985 #endif 1986 1987 pf->tq = taskqueue_create_fast("ixl_adm", M_NOWAIT, 1988 taskqueue_thread_enqueue, &pf->tq); 1989 taskqueue_start_threads(&pf->tq, 1, PI_NET, "%s adminq", 1990 device_get_nameunit(dev)); 1991 1992 return (0); 1993 } 1994 1995 1996 /********************************************************************* 1997 * 1998 * Setup MSIX Interrupt resources and handlers for the VSI 1999 * 2000 **********************************************************************/ 2001 static int 2002 ixl_assign_vsi_msix(struct ixl_pf *pf) 2003 { 2004 device_t dev = pf->dev; 2005 struct ixl_vsi *vsi = &pf->vsi; 2006 struct ixl_queue *que = vsi->queues; 2007 struct tx_ring *txr; 2008 int error, rid, vector = 0; 2009 #ifdef RSS 2010 cpuset_t cpu_mask; 2011 #endif 2012 2013 /* Admin Que is vector 0*/ 2014 rid = vector + 1; 2015 pf->res = bus_alloc_resource_any(dev, 2016 SYS_RES_IRQ, &rid, RF_SHAREABLE | RF_ACTIVE); 2017 if (!pf->res) { 2018 device_printf(dev,"Unable to allocate" 2019 " bus resource: Adminq interrupt [%d]\n", rid); 2020 return (ENXIO); 2021 } 2022 /* Set the adminq vector and handler */ 2023 error = bus_setup_intr(dev, pf->res, 2024 INTR_TYPE_NET | INTR_MPSAFE, NULL, 2025 ixl_msix_adminq, pf, &pf->tag); 2026 if (error) { 2027 pf->res = NULL; 2028 device_printf(dev, "Failed to register Admin que handler"); 2029 return (error); 2030 } 2031 bus_describe_intr(dev, pf->res, pf->tag, "aq"); 2032 pf->admvec = vector; 2033 /* Tasklet for Admin Queue */ 2034 TASK_INIT(&pf->adminq, 0, ixl_do_adminq, pf); 2035 2036 #ifdef PCI_IOV 2037 TASK_INIT(&pf->vflr_task, 0, ixl_handle_vflr, pf); 2038 #endif 2039 2040 pf->tq = taskqueue_create_fast("ixl_adm", M_NOWAIT, 2041 taskqueue_thread_enqueue, &pf->tq); 2042 taskqueue_start_threads(&pf->tq, 1, PI_NET, "%s adminq", 2043 device_get_nameunit(pf->dev)); 2044 ++vector; 2045 2046 /* Now set up the stations */ 2047 for (int i = 0; i < vsi->num_queues; i++, vector++, que++) { 2048 int cpu_id = i; 2049 rid = vector + 1; 2050 txr = &que->txr; 2051 que->res = bus_alloc_resource_any(dev, SYS_RES_IRQ, &rid, 2052 RF_SHAREABLE | RF_ACTIVE); 2053 if (que->res == NULL) { 2054 device_printf(dev,"Unable to allocate" 2055 " bus resource: que interrupt [%d]\n", vector); 2056 return (ENXIO); 2057 } 2058 /* Set the handler function */ 2059 error = bus_setup_intr(dev, que->res, 2060 INTR_TYPE_NET | INTR_MPSAFE, NULL, 2061 ixl_msix_que, que, &que->tag); 2062 if (error) { 2063 que->res = NULL; 2064 device_printf(dev, "Failed to register que handler"); 2065 return (error); 2066 } 2067 bus_describe_intr(dev, que->res, que->tag, "q%d", i); 2068 /* Bind the vector to a CPU */ 2069 #ifdef RSS 2070 cpu_id = rss_getcpu(i % rss_getnumbuckets()); 2071 #endif 2072 bus_bind_intr(dev, que->res, cpu_id); 2073 que->msix = vector; 2074 TASK_INIT(&que->tx_task, 0, ixl_deferred_mq_start, que); 2075 TASK_INIT(&que->task, 0, ixl_handle_que, que); 2076 que->tq = taskqueue_create_fast("ixl_que", M_NOWAIT, 2077 taskqueue_thread_enqueue, &que->tq); 2078 #ifdef RSS 2079 CPU_SETOF(cpu_id, &cpu_mask); 2080 taskqueue_start_threads_cpuset(&que->tq, 1, PI_NET, 2081 &cpu_mask, "%s (bucket %d)", 2082 device_get_nameunit(dev), cpu_id); 2083 #else 2084 taskqueue_start_threads(&que->tq, 1, PI_NET, 2085 "%s que", device_get_nameunit(dev)); 2086 #endif 2087 } 2088 2089 return (0); 2090 } 2091 2092 2093 /* 2094 * Allocate MSI/X vectors 2095 */ 2096 static int 2097 ixl_init_msix(struct ixl_pf *pf) 2098 { 2099 device_t dev = pf->dev; 2100 int rid, want, vectors, queues, available; 2101 2102 /* Override by tuneable */ 2103 if (ixl_enable_msix == 0) 2104 goto msi; 2105 2106 /* 2107 ** When used in a virtualized environment 2108 ** PCI BUSMASTER capability may not be set 2109 ** so explicity set it here and rewrite 2110 ** the ENABLE in the MSIX control register 2111 ** at this point to cause the host to 2112 ** successfully initialize us. 2113 */ 2114 { 2115 u16 pci_cmd_word; 2116 int msix_ctrl; 2117 pci_cmd_word = pci_read_config(dev, PCIR_COMMAND, 2); 2118 pci_cmd_word |= PCIM_CMD_BUSMASTEREN; 2119 pci_write_config(dev, PCIR_COMMAND, pci_cmd_word, 2); 2120 pci_find_cap(dev, PCIY_MSIX, &rid); 2121 rid += PCIR_MSIX_CTRL; 2122 msix_ctrl = pci_read_config(dev, rid, 2); 2123 msix_ctrl |= PCIM_MSIXCTRL_MSIX_ENABLE; 2124 pci_write_config(dev, rid, msix_ctrl, 2); 2125 } 2126 2127 /* First try MSI/X */ 2128 rid = PCIR_BAR(IXL_BAR); 2129 pf->msix_mem = bus_alloc_resource_any(dev, 2130 SYS_RES_MEMORY, &rid, RF_ACTIVE); 2131 if (!pf->msix_mem) { 2132 /* May not be enabled */ 2133 device_printf(pf->dev, 2134 "Unable to map MSIX table \n"); 2135 goto msi; 2136 } 2137 2138 available = pci_msix_count(dev); 2139 if (available == 0) { /* system has msix disabled */ 2140 bus_release_resource(dev, SYS_RES_MEMORY, 2141 rid, pf->msix_mem); 2142 pf->msix_mem = NULL; 2143 goto msi; 2144 } 2145 2146 /* Figure out a reasonable auto config value */ 2147 queues = (mp_ncpus > (available - 1)) ? (available - 1) : mp_ncpus; 2148 2149 /* Override with hardcoded value if sane */ 2150 if ((ixl_max_queues != 0) && (ixl_max_queues <= queues)) 2151 queues = ixl_max_queues; 2152 2153 #ifdef RSS 2154 /* If we're doing RSS, clamp at the number of RSS buckets */ 2155 if (queues > rss_getnumbuckets()) 2156 queues = rss_getnumbuckets(); 2157 #endif 2158 2159 /* 2160 ** Want one vector (RX/TX pair) per queue 2161 ** plus an additional for the admin queue. 2162 */ 2163 want = queues + 1; 2164 if (want <= available) /* Have enough */ 2165 vectors = want; 2166 else { 2167 device_printf(pf->dev, 2168 "MSIX Configuration Problem, " 2169 "%d vectors available but %d wanted!\n", 2170 available, want); 2171 return (0); /* Will go to Legacy setup */ 2172 } 2173 2174 if (pci_alloc_msix(dev, &vectors) == 0) { 2175 device_printf(pf->dev, 2176 "Using MSIX interrupts with %d vectors\n", vectors); 2177 pf->msix = vectors; 2178 pf->vsi.num_queues = queues; 2179 #ifdef RSS 2180 /* 2181 * If we're doing RSS, the number of queues needs to 2182 * match the number of RSS buckets that are configured. 2183 * 2184 * + If there's more queues than RSS buckets, we'll end 2185 * up with queues that get no traffic. 2186 * 2187 * + If there's more RSS buckets than queues, we'll end 2188 * up having multiple RSS buckets map to the same queue, 2189 * so there'll be some contention. 2190 */ 2191 if (queues != rss_getnumbuckets()) { 2192 device_printf(dev, 2193 "%s: queues (%d) != RSS buckets (%d)" 2194 "; performance will be impacted.\n", 2195 __func__, queues, rss_getnumbuckets()); 2196 } 2197 #endif 2198 return (vectors); 2199 } 2200 msi: 2201 vectors = pci_msi_count(dev); 2202 pf->vsi.num_queues = 1; 2203 pf->msix = 1; 2204 ixl_max_queues = 1; 2205 ixl_enable_msix = 0; 2206 if (vectors == 1 && pci_alloc_msi(dev, &vectors) == 0) 2207 device_printf(pf->dev,"Using an MSI interrupt\n"); 2208 else { 2209 pf->msix = 0; 2210 device_printf(pf->dev,"Using a Legacy interrupt\n"); 2211 } 2212 return (vectors); 2213 } 2214 2215 2216 /* 2217 * Plumb MSI/X vectors 2218 */ 2219 static void 2220 ixl_configure_msix(struct ixl_pf *pf) 2221 { 2222 struct i40e_hw *hw = &pf->hw; 2223 struct ixl_vsi *vsi = &pf->vsi; 2224 u32 reg; 2225 u16 vector = 1; 2226 2227 /* First set up the adminq - vector 0 */ 2228 wr32(hw, I40E_PFINT_ICR0_ENA, 0); /* disable all */ 2229 rd32(hw, I40E_PFINT_ICR0); /* read to clear */ 2230 2231 reg = I40E_PFINT_ICR0_ENA_ECC_ERR_MASK | 2232 I40E_PFINT_ICR0_ENA_GRST_MASK | 2233 I40E_PFINT_ICR0_HMC_ERR_MASK | 2234 I40E_PFINT_ICR0_ENA_ADMINQ_MASK | 2235 I40E_PFINT_ICR0_ENA_MAL_DETECT_MASK | 2236 I40E_PFINT_ICR0_ENA_VFLR_MASK | 2237 I40E_PFINT_ICR0_ENA_PCI_EXCEPTION_MASK; 2238 wr32(hw, I40E_PFINT_ICR0_ENA, reg); 2239 2240 wr32(hw, I40E_PFINT_LNKLST0, 0x7FF); 2241 wr32(hw, I40E_PFINT_ITR0(IXL_RX_ITR), 0x003E); 2242 2243 wr32(hw, I40E_PFINT_DYN_CTL0, 2244 I40E_PFINT_DYN_CTL0_SW_ITR_INDX_MASK | 2245 I40E_PFINT_DYN_CTL0_INTENA_MSK_MASK); 2246 2247 wr32(hw, I40E_PFINT_STAT_CTL0, 0); 2248 2249 /* Next configure the queues */ 2250 for (int i = 0; i < vsi->num_queues; i++, vector++) { 2251 wr32(hw, I40E_PFINT_DYN_CTLN(i), i); 2252 wr32(hw, I40E_PFINT_LNKLSTN(i), i); 2253 2254 reg = I40E_QINT_RQCTL_CAUSE_ENA_MASK | 2255 (IXL_RX_ITR << I40E_QINT_RQCTL_ITR_INDX_SHIFT) | 2256 (vector << I40E_QINT_RQCTL_MSIX_INDX_SHIFT) | 2257 (i << I40E_QINT_RQCTL_NEXTQ_INDX_SHIFT) | 2258 (I40E_QUEUE_TYPE_TX << I40E_QINT_RQCTL_NEXTQ_TYPE_SHIFT); 2259 wr32(hw, I40E_QINT_RQCTL(i), reg); 2260 2261 reg = I40E_QINT_TQCTL_CAUSE_ENA_MASK | 2262 (IXL_TX_ITR << I40E_QINT_TQCTL_ITR_INDX_SHIFT) | 2263 (vector << I40E_QINT_TQCTL_MSIX_INDX_SHIFT) | 2264 ((i+1) << I40E_QINT_TQCTL_NEXTQ_INDX_SHIFT) | 2265 (I40E_QUEUE_TYPE_RX << I40E_QINT_TQCTL_NEXTQ_TYPE_SHIFT); 2266 if (i == (vsi->num_queues - 1)) 2267 reg |= (IXL_QUEUE_EOL 2268 << I40E_QINT_TQCTL_NEXTQ_INDX_SHIFT); 2269 wr32(hw, I40E_QINT_TQCTL(i), reg); 2270 } 2271 } 2272 2273 /* 2274 * Configure for MSI single vector operation 2275 */ 2276 static void 2277 ixl_configure_legacy(struct ixl_pf *pf) 2278 { 2279 struct i40e_hw *hw = &pf->hw; 2280 u32 reg; 2281 2282 2283 wr32(hw, I40E_PFINT_ITR0(0), 0); 2284 wr32(hw, I40E_PFINT_ITR0(1), 0); 2285 2286 2287 /* Setup "other" causes */ 2288 reg = I40E_PFINT_ICR0_ENA_ECC_ERR_MASK 2289 | I40E_PFINT_ICR0_ENA_MAL_DETECT_MASK 2290 | I40E_PFINT_ICR0_ENA_GRST_MASK 2291 | I40E_PFINT_ICR0_ENA_PCI_EXCEPTION_MASK 2292 | I40E_PFINT_ICR0_ENA_GPIO_MASK 2293 | I40E_PFINT_ICR0_ENA_LINK_STAT_CHANGE_MASK 2294 | I40E_PFINT_ICR0_ENA_HMC_ERR_MASK 2295 | I40E_PFINT_ICR0_ENA_PE_CRITERR_MASK 2296 | I40E_PFINT_ICR0_ENA_VFLR_MASK 2297 | I40E_PFINT_ICR0_ENA_ADMINQ_MASK 2298 ; 2299 wr32(hw, I40E_PFINT_ICR0_ENA, reg); 2300 2301 /* SW_ITR_IDX = 0, but don't change INTENA */ 2302 wr32(hw, I40E_PFINT_DYN_CTL0, 2303 I40E_PFINT_DYN_CTLN_SW_ITR_INDX_MASK | 2304 I40E_PFINT_DYN_CTLN_INTENA_MSK_MASK); 2305 /* SW_ITR_IDX = 0, OTHER_ITR_IDX = 0 */ 2306 wr32(hw, I40E_PFINT_STAT_CTL0, 0); 2307 2308 /* FIRSTQ_INDX = 0, FIRSTQ_TYPE = 0 (rx) */ 2309 wr32(hw, I40E_PFINT_LNKLST0, 0); 2310 2311 /* Associate the queue pair to the vector and enable the q int */ 2312 reg = I40E_QINT_RQCTL_CAUSE_ENA_MASK 2313 | (IXL_RX_ITR << I40E_QINT_RQCTL_ITR_INDX_SHIFT) 2314 | (I40E_QUEUE_TYPE_TX << I40E_QINT_TQCTL_NEXTQ_TYPE_SHIFT); 2315 wr32(hw, I40E_QINT_RQCTL(0), reg); 2316 2317 reg = I40E_QINT_TQCTL_CAUSE_ENA_MASK 2318 | (IXL_TX_ITR << I40E_QINT_TQCTL_ITR_INDX_SHIFT) 2319 | (IXL_QUEUE_EOL << I40E_QINT_TQCTL_NEXTQ_INDX_SHIFT); 2320 wr32(hw, I40E_QINT_TQCTL(0), reg); 2321 2322 /* Next enable the queue pair */ 2323 reg = rd32(hw, I40E_QTX_ENA(0)); 2324 reg |= I40E_QTX_ENA_QENA_REQ_MASK; 2325 wr32(hw, I40E_QTX_ENA(0), reg); 2326 2327 reg = rd32(hw, I40E_QRX_ENA(0)); 2328 reg |= I40E_QRX_ENA_QENA_REQ_MASK; 2329 wr32(hw, I40E_QRX_ENA(0), reg); 2330 } 2331 2332 2333 /* 2334 * Set the Initial ITR state 2335 */ 2336 static void 2337 ixl_configure_itr(struct ixl_pf *pf) 2338 { 2339 struct i40e_hw *hw = &pf->hw; 2340 struct ixl_vsi *vsi = &pf->vsi; 2341 struct ixl_queue *que = vsi->queues; 2342 2343 vsi->rx_itr_setting = ixl_rx_itr; 2344 if (ixl_dynamic_rx_itr) 2345 vsi->rx_itr_setting |= IXL_ITR_DYNAMIC; 2346 vsi->tx_itr_setting = ixl_tx_itr; 2347 if (ixl_dynamic_tx_itr) 2348 vsi->tx_itr_setting |= IXL_ITR_DYNAMIC; 2349 2350 for (int i = 0; i < vsi->num_queues; i++, que++) { 2351 struct tx_ring *txr = &que->txr; 2352 struct rx_ring *rxr = &que->rxr; 2353 2354 wr32(hw, I40E_PFINT_ITRN(IXL_RX_ITR, i), 2355 vsi->rx_itr_setting); 2356 rxr->itr = vsi->rx_itr_setting; 2357 rxr->latency = IXL_AVE_LATENCY; 2358 wr32(hw, I40E_PFINT_ITRN(IXL_TX_ITR, i), 2359 vsi->tx_itr_setting); 2360 txr->itr = vsi->tx_itr_setting; 2361 txr->latency = IXL_AVE_LATENCY; 2362 } 2363 } 2364 2365 2366 static int 2367 ixl_allocate_pci_resources(struct ixl_pf *pf) 2368 { 2369 int rid; 2370 device_t dev = pf->dev; 2371 2372 rid = PCIR_BAR(0); 2373 pf->pci_mem = bus_alloc_resource_any(dev, SYS_RES_MEMORY, 2374 &rid, RF_ACTIVE); 2375 2376 if (!(pf->pci_mem)) { 2377 device_printf(dev,"Unable to allocate bus resource: memory\n"); 2378 return (ENXIO); 2379 } 2380 2381 pf->osdep.mem_bus_space_tag = 2382 rman_get_bustag(pf->pci_mem); 2383 pf->osdep.mem_bus_space_handle = 2384 rman_get_bushandle(pf->pci_mem); 2385 pf->osdep.mem_bus_space_size = rman_get_size(pf->pci_mem); 2386 pf->osdep.flush_reg = I40E_GLGEN_STAT; 2387 pf->hw.hw_addr = (u8 *) &pf->osdep.mem_bus_space_handle; 2388 2389 pf->hw.back = &pf->osdep; 2390 2391 /* 2392 ** Now setup MSI or MSI/X, should 2393 ** return us the number of supported 2394 ** vectors. (Will be 1 for MSI) 2395 */ 2396 pf->msix = ixl_init_msix(pf); 2397 return (0); 2398 } 2399 2400 static void 2401 ixl_free_pci_resources(struct ixl_pf * pf) 2402 { 2403 struct ixl_vsi *vsi = &pf->vsi; 2404 struct ixl_queue *que = vsi->queues; 2405 device_t dev = pf->dev; 2406 int rid, memrid; 2407 2408 memrid = PCIR_BAR(IXL_BAR); 2409 2410 /* We may get here before stations are setup */ 2411 if ((!ixl_enable_msix) || (que == NULL)) 2412 goto early; 2413 2414 /* 2415 ** Release all msix VSI resources: 2416 */ 2417 for (int i = 0; i < vsi->num_queues; i++, que++) { 2418 rid = que->msix + 1; 2419 if (que->tag != NULL) { 2420 bus_teardown_intr(dev, que->res, que->tag); 2421 que->tag = NULL; 2422 } 2423 if (que->res != NULL) 2424 bus_release_resource(dev, SYS_RES_IRQ, rid, que->res); 2425 } 2426 2427 early: 2428 /* Clean the AdminQ interrupt last */ 2429 if (pf->admvec) /* we are doing MSIX */ 2430 rid = pf->admvec + 1; 2431 else 2432 (pf->msix != 0) ? (rid = 1):(rid = 0); 2433 2434 if (pf->tag != NULL) { 2435 bus_teardown_intr(dev, pf->res, pf->tag); 2436 pf->tag = NULL; 2437 } 2438 if (pf->res != NULL) 2439 bus_release_resource(dev, SYS_RES_IRQ, rid, pf->res); 2440 2441 if (pf->msix) 2442 pci_release_msi(dev); 2443 2444 if (pf->msix_mem != NULL) 2445 bus_release_resource(dev, SYS_RES_MEMORY, 2446 memrid, pf->msix_mem); 2447 2448 if (pf->pci_mem != NULL) 2449 bus_release_resource(dev, SYS_RES_MEMORY, 2450 PCIR_BAR(0), pf->pci_mem); 2451 2452 return; 2453 } 2454 2455 static void 2456 ixl_add_ifmedia(struct ixl_vsi *vsi, u32 phy_type) 2457 { 2458 /* Display supported media types */ 2459 if (phy_type & (1 << I40E_PHY_TYPE_100BASE_TX)) 2460 ifmedia_add(&vsi->media, IFM_ETHER | IFM_100_TX, 0, NULL); 2461 2462 if (phy_type & (1 << I40E_PHY_TYPE_1000BASE_T)) 2463 ifmedia_add(&vsi->media, IFM_ETHER | IFM_1000_T, 0, NULL); 2464 if (phy_type & (1 << I40E_PHY_TYPE_1000BASE_SX)) 2465 ifmedia_add(&vsi->media, IFM_ETHER | IFM_1000_SX, 0, NULL); 2466 if (phy_type & (1 << I40E_PHY_TYPE_1000BASE_LX)) 2467 ifmedia_add(&vsi->media, IFM_ETHER | IFM_1000_LX, 0, NULL); 2468 2469 if (phy_type & (1 << I40E_PHY_TYPE_XAUI) || 2470 phy_type & (1 << I40E_PHY_TYPE_XFI) || 2471 phy_type & (1 << I40E_PHY_TYPE_10GBASE_SFPP_CU)) 2472 ifmedia_add(&vsi->media, IFM_ETHER | IFM_10G_TWINAX, 0, NULL); 2473 2474 if (phy_type & (1 << I40E_PHY_TYPE_10GBASE_SR)) 2475 ifmedia_add(&vsi->media, IFM_ETHER | IFM_10G_SR, 0, NULL); 2476 if (phy_type & (1 << I40E_PHY_TYPE_10GBASE_LR)) 2477 ifmedia_add(&vsi->media, IFM_ETHER | IFM_10G_LR, 0, NULL); 2478 if (phy_type & (1 << I40E_PHY_TYPE_10GBASE_T)) 2479 ifmedia_add(&vsi->media, IFM_ETHER | IFM_10G_T, 0, NULL); 2480 2481 if (phy_type & (1 << I40E_PHY_TYPE_40GBASE_CR4) || 2482 phy_type & (1 << I40E_PHY_TYPE_40GBASE_CR4_CU) || 2483 phy_type & (1 << I40E_PHY_TYPE_40GBASE_AOC) || 2484 phy_type & (1 << I40E_PHY_TYPE_XLAUI) || 2485 phy_type & (1 << I40E_PHY_TYPE_40GBASE_KR4)) 2486 ifmedia_add(&vsi->media, IFM_ETHER | IFM_40G_CR4, 0, NULL); 2487 if (phy_type & (1 << I40E_PHY_TYPE_40GBASE_SR4)) 2488 ifmedia_add(&vsi->media, IFM_ETHER | IFM_40G_SR4, 0, NULL); 2489 if (phy_type & (1 << I40E_PHY_TYPE_40GBASE_LR4)) 2490 ifmedia_add(&vsi->media, IFM_ETHER | IFM_40G_LR4, 0, NULL); 2491 2492 #ifndef IFM_ETH_XTYPE 2493 if (phy_type & (1 << I40E_PHY_TYPE_1000BASE_KX)) 2494 ifmedia_add(&vsi->media, IFM_ETHER | IFM_1000_CX, 0, NULL); 2495 2496 if (phy_type & (1 << I40E_PHY_TYPE_10GBASE_CR1_CU) || 2497 phy_type & (1 << I40E_PHY_TYPE_10GBASE_CR1) || 2498 phy_type & (1 << I40E_PHY_TYPE_10GBASE_AOC) || 2499 phy_type & (1 << I40E_PHY_TYPE_SFI)) 2500 ifmedia_add(&vsi->media, IFM_ETHER | IFM_10G_TWINAX, 0, NULL); 2501 if (phy_type & (1 << I40E_PHY_TYPE_10GBASE_KX4)) 2502 ifmedia_add(&vsi->media, IFM_ETHER | IFM_10G_CX4, 0, NULL); 2503 if (phy_type & (1 << I40E_PHY_TYPE_10GBASE_KR)) 2504 ifmedia_add(&vsi->media, IFM_ETHER | IFM_10G_SR, 0, NULL); 2505 2506 if (phy_type & (1 << I40E_PHY_TYPE_40GBASE_KR4)) 2507 ifmedia_add(&vsi->media, IFM_ETHER | IFM_40G_SR4, 0, NULL); 2508 if (phy_type & (1 << I40E_PHY_TYPE_XLPPI)) 2509 ifmedia_add(&vsi->media, IFM_ETHER | IFM_40G_CR4, 0, NULL); 2510 #else 2511 if (phy_type & (1 << I40E_PHY_TYPE_1000BASE_KX)) 2512 ifmedia_add(&vsi->media, IFM_ETHER | IFM_1000_KX, 0, NULL); 2513 2514 if (phy_type & (1 << I40E_PHY_TYPE_10GBASE_CR1_CU) 2515 || phy_type & (1 << I40E_PHY_TYPE_10GBASE_CR1)) 2516 ifmedia_add(&vsi->media, IFM_ETHER | IFM_10G_CR1, 0, NULL); 2517 if (phy_type & (1 << I40E_PHY_TYPE_10GBASE_AOC)) 2518 ifmedia_add(&vsi->media, IFM_ETHER | IFM_10G_TWINAX_LONG, 0, NULL); 2519 if (phy_type & (1 << I40E_PHY_TYPE_SFI)) 2520 ifmedia_add(&vsi->media, IFM_ETHER | IFM_10G_SFI, 0, NULL); 2521 if (phy_type & (1 << I40E_PHY_TYPE_10GBASE_KX4)) 2522 ifmedia_add(&vsi->media, IFM_ETHER | IFM_10G_KX4, 0, NULL); 2523 if (phy_type & (1 << I40E_PHY_TYPE_10GBASE_KR)) 2524 ifmedia_add(&vsi->media, IFM_ETHER | IFM_10G_KR, 0, NULL); 2525 2526 if (phy_type & (1 << I40E_PHY_TYPE_20GBASE_KR2)) 2527 ifmedia_add(&vsi->media, IFM_ETHER | IFM_20G_KR2, 0, NULL); 2528 2529 if (phy_type & (1 << I40E_PHY_TYPE_40GBASE_KR4)) 2530 ifmedia_add(&vsi->media, IFM_ETHER | IFM_40G_KR4, 0, NULL); 2531 if (phy_type & (1 << I40E_PHY_TYPE_XLPPI)) 2532 ifmedia_add(&vsi->media, IFM_ETHER | IFM_40G_XLPPI, 0, NULL); 2533 #endif 2534 } 2535 2536 /********************************************************************* 2537 * 2538 * Setup networking device structure and register an interface. 2539 * 2540 **********************************************************************/ 2541 static int 2542 ixl_setup_interface(device_t dev, struct ixl_vsi *vsi) 2543 { 2544 struct ifnet *ifp; 2545 struct i40e_hw *hw = vsi->hw; 2546 struct ixl_queue *que = vsi->queues; 2547 struct i40e_aq_get_phy_abilities_resp abilities; 2548 enum i40e_status_code aq_error = 0; 2549 2550 INIT_DEBUGOUT("ixl_setup_interface: begin"); 2551 2552 ifp = vsi->ifp = if_alloc(IFT_ETHER); 2553 if (ifp == NULL) { 2554 device_printf(dev, "can not allocate ifnet structure\n"); 2555 return (-1); 2556 } 2557 if_initname(ifp, device_get_name(dev), device_get_unit(dev)); 2558 ifp->if_mtu = ETHERMTU; 2559 ifp->if_baudrate = IF_Gbps(40); 2560 ifp->if_init = ixl_init; 2561 ifp->if_softc = vsi; 2562 ifp->if_flags = IFF_BROADCAST | IFF_SIMPLEX | IFF_MULTICAST; 2563 ifp->if_ioctl = ixl_ioctl; 2564 2565 #if __FreeBSD_version >= 1100036 2566 if_setgetcounterfn(ifp, ixl_get_counter); 2567 #endif 2568 2569 ifp->if_transmit = ixl_mq_start; 2570 2571 ifp->if_qflush = ixl_qflush; 2572 2573 ifp->if_snd.ifq_maxlen = que->num_desc - 2; 2574 2575 vsi->max_frame_size = 2576 ifp->if_mtu + ETHER_HDR_LEN + ETHER_CRC_LEN 2577 + ETHER_VLAN_ENCAP_LEN; 2578 2579 /* 2580 * Tell the upper layer(s) we support long frames. 2581 */ 2582 ifp->if_hdrlen = sizeof(struct ether_vlan_header); 2583 2584 ifp->if_capabilities |= IFCAP_HWCSUM; 2585 ifp->if_capabilities |= IFCAP_HWCSUM_IPV6; 2586 ifp->if_capabilities |= IFCAP_TSO; 2587 ifp->if_capabilities |= IFCAP_JUMBO_MTU; 2588 ifp->if_capabilities |= IFCAP_LRO; 2589 2590 /* VLAN capabilties */ 2591 ifp->if_capabilities |= IFCAP_VLAN_HWTAGGING 2592 | IFCAP_VLAN_HWTSO 2593 | IFCAP_VLAN_MTU 2594 | IFCAP_VLAN_HWCSUM; 2595 ifp->if_capenable = ifp->if_capabilities; 2596 2597 /* 2598 ** Don't turn this on by default, if vlans are 2599 ** created on another pseudo device (eg. lagg) 2600 ** then vlan events are not passed thru, breaking 2601 ** operation, but with HW FILTER off it works. If 2602 ** using vlans directly on the ixl driver you can 2603 ** enable this and get full hardware tag filtering. 2604 */ 2605 ifp->if_capabilities |= IFCAP_VLAN_HWFILTER; 2606 2607 /* 2608 * Specify the media types supported by this adapter and register 2609 * callbacks to update media and link information 2610 */ 2611 ifmedia_init(&vsi->media, IFM_IMASK, ixl_media_change, 2612 ixl_media_status); 2613 2614 aq_error = i40e_aq_get_phy_capabilities(hw, 2615 FALSE, TRUE, &abilities, NULL); 2616 /* May need delay to detect fiber correctly */ 2617 if (aq_error == I40E_ERR_UNKNOWN_PHY) { 2618 i40e_msec_delay(200); 2619 aq_error = i40e_aq_get_phy_capabilities(hw, FALSE, 2620 TRUE, &abilities, NULL); 2621 } 2622 if (aq_error) { 2623 if (aq_error == I40E_ERR_UNKNOWN_PHY) 2624 device_printf(dev, "Unknown PHY type detected!\n"); 2625 else 2626 device_printf(dev, 2627 "Error getting supported media types, err %d," 2628 " AQ error %d\n", aq_error, hw->aq.asq_last_status); 2629 return (0); 2630 } 2631 2632 ixl_add_ifmedia(vsi, abilities.phy_type); 2633 2634 /* Use autoselect media by default */ 2635 ifmedia_add(&vsi->media, IFM_ETHER | IFM_AUTO, 0, NULL); 2636 ifmedia_set(&vsi->media, IFM_ETHER | IFM_AUTO); 2637 2638 ether_ifattach(ifp, hw->mac.addr); 2639 2640 return (0); 2641 } 2642 2643 /* 2644 ** Run when the Admin Queue gets a 2645 ** link transition interrupt. 2646 */ 2647 static void 2648 ixl_link_event(struct ixl_pf *pf, struct i40e_arq_event_info *e) 2649 { 2650 struct i40e_hw *hw = &pf->hw; 2651 struct i40e_aqc_get_link_status *status = 2652 (struct i40e_aqc_get_link_status *)&e->desc.params.raw; 2653 bool check; 2654 2655 hw->phy.get_link_info = TRUE; 2656 i40e_get_link_status(hw, &check); 2657 pf->link_up = check; 2658 #ifdef IXL_DEBUG 2659 printf("Link is %s\n", check ? "up":"down"); 2660 #endif 2661 /* Report if Unqualified modules are found */ 2662 if ((status->link_info & I40E_AQ_MEDIA_AVAILABLE) && 2663 (!(status->an_info & I40E_AQ_QUALIFIED_MODULE)) && 2664 (!(status->link_info & I40E_AQ_LINK_UP))) 2665 device_printf(pf->dev, "Link failed because " 2666 "an unqualified module was detected\n"); 2667 2668 return; 2669 } 2670 2671 /********************************************************************* 2672 * 2673 * Get Firmware Switch configuration 2674 * - this will need to be more robust when more complex 2675 * switch configurations are enabled. 2676 * 2677 **********************************************************************/ 2678 static int 2679 ixl_switch_config(struct ixl_pf *pf) 2680 { 2681 struct i40e_hw *hw = &pf->hw; 2682 struct ixl_vsi *vsi = &pf->vsi; 2683 device_t dev = vsi->dev; 2684 struct i40e_aqc_get_switch_config_resp *sw_config; 2685 u8 aq_buf[I40E_AQ_LARGE_BUF]; 2686 int ret; 2687 u16 next = 0; 2688 2689 memset(&aq_buf, 0, sizeof(aq_buf)); 2690 sw_config = (struct i40e_aqc_get_switch_config_resp *)aq_buf; 2691 ret = i40e_aq_get_switch_config(hw, sw_config, 2692 sizeof(aq_buf), &next, NULL); 2693 if (ret) { 2694 device_printf(dev,"aq_get_switch_config failed (ret=%d)!!\n", 2695 ret); 2696 return (ret); 2697 } 2698 #ifdef IXL_DEBUG 2699 device_printf(dev, 2700 "Switch config: header reported: %d in structure, %d total\n", 2701 sw_config->header.num_reported, sw_config->header.num_total); 2702 for (int i = 0; i < sw_config->header.num_reported; i++) { 2703 device_printf(dev, 2704 "%d: type=%d seid=%d uplink=%d downlink=%d\n", i, 2705 sw_config->element[i].element_type, 2706 sw_config->element[i].seid, 2707 sw_config->element[i].uplink_seid, 2708 sw_config->element[i].downlink_seid); 2709 } 2710 #endif 2711 /* Simplified due to a single VSI at the moment */ 2712 vsi->uplink_seid = sw_config->element[0].uplink_seid; 2713 vsi->downlink_seid = sw_config->element[0].downlink_seid; 2714 vsi->seid = sw_config->element[0].seid; 2715 return (ret); 2716 } 2717 2718 /********************************************************************* 2719 * 2720 * Initialize the VSI: this handles contexts, which means things 2721 * like the number of descriptors, buffer size, 2722 * plus we init the rings thru this function. 2723 * 2724 **********************************************************************/ 2725 static int 2726 ixl_initialize_vsi(struct ixl_vsi *vsi) 2727 { 2728 struct ixl_pf *pf = vsi->back; 2729 struct ixl_queue *que = vsi->queues; 2730 device_t dev = vsi->dev; 2731 struct i40e_hw *hw = vsi->hw; 2732 struct i40e_vsi_context ctxt; 2733 int err = 0; 2734 2735 memset(&ctxt, 0, sizeof(ctxt)); 2736 ctxt.seid = vsi->seid; 2737 if (pf->veb_seid != 0) 2738 ctxt.uplink_seid = pf->veb_seid; 2739 ctxt.pf_num = hw->pf_id; 2740 err = i40e_aq_get_vsi_params(hw, &ctxt, NULL); 2741 if (err) { 2742 device_printf(dev,"get vsi params failed %x!!\n", err); 2743 return (err); 2744 } 2745 #ifdef IXL_DEBUG 2746 printf("get_vsi_params: seid: %d, uplinkseid: %d, vsi_number: %d, " 2747 "vsis_allocated: %d, vsis_unallocated: %d, flags: 0x%x, " 2748 "pfnum: %d, vfnum: %d, stat idx: %d, enabled: %d\n", ctxt.seid, 2749 ctxt.uplink_seid, ctxt.vsi_number, 2750 ctxt.vsis_allocated, ctxt.vsis_unallocated, 2751 ctxt.flags, ctxt.pf_num, ctxt.vf_num, 2752 ctxt.info.stat_counter_idx, ctxt.info.up_enable_bits); 2753 #endif 2754 /* 2755 ** Set the queue and traffic class bits 2756 ** - when multiple traffic classes are supported 2757 ** this will need to be more robust. 2758 */ 2759 ctxt.info.valid_sections = I40E_AQ_VSI_PROP_QUEUE_MAP_VALID; 2760 ctxt.info.mapping_flags |= I40E_AQ_VSI_QUE_MAP_CONTIG; 2761 ctxt.info.queue_mapping[0] = 0; 2762 ctxt.info.tc_mapping[0] = 0x0800; 2763 2764 /* Set VLAN receive stripping mode */ 2765 ctxt.info.valid_sections |= I40E_AQ_VSI_PROP_VLAN_VALID; 2766 ctxt.info.port_vlan_flags = I40E_AQ_VSI_PVLAN_MODE_ALL; 2767 if (vsi->ifp->if_capenable & IFCAP_VLAN_HWTAGGING) 2768 ctxt.info.port_vlan_flags |= I40E_AQ_VSI_PVLAN_EMOD_STR_BOTH; 2769 else 2770 ctxt.info.port_vlan_flags |= I40E_AQ_VSI_PVLAN_EMOD_NOTHING; 2771 2772 /* Keep copy of VSI info in VSI for statistic counters */ 2773 memcpy(&vsi->info, &ctxt.info, sizeof(ctxt.info)); 2774 2775 /* Reset VSI statistics */ 2776 ixl_vsi_reset_stats(vsi); 2777 vsi->hw_filters_add = 0; 2778 vsi->hw_filters_del = 0; 2779 2780 ctxt.flags = htole16(I40E_AQ_VSI_TYPE_PF); 2781 2782 err = i40e_aq_update_vsi_params(hw, &ctxt, NULL); 2783 if (err) { 2784 device_printf(dev,"update vsi params failed %x!!\n", 2785 hw->aq.asq_last_status); 2786 return (err); 2787 } 2788 2789 for (int i = 0; i < vsi->num_queues; i++, que++) { 2790 struct tx_ring *txr = &que->txr; 2791 struct rx_ring *rxr = &que->rxr; 2792 struct i40e_hmc_obj_txq tctx; 2793 struct i40e_hmc_obj_rxq rctx; 2794 u32 txctl; 2795 u16 size; 2796 2797 2798 /* Setup the HMC TX Context */ 2799 size = que->num_desc * sizeof(struct i40e_tx_desc); 2800 memset(&tctx, 0, sizeof(struct i40e_hmc_obj_txq)); 2801 tctx.new_context = 1; 2802 tctx.base = (txr->dma.pa/IXL_TX_CTX_BASE_UNITS); 2803 tctx.qlen = que->num_desc; 2804 tctx.fc_ena = 0; 2805 tctx.rdylist = vsi->info.qs_handle[0]; /* index is TC */ 2806 /* Enable HEAD writeback */ 2807 tctx.head_wb_ena = 1; 2808 tctx.head_wb_addr = txr->dma.pa + 2809 (que->num_desc * sizeof(struct i40e_tx_desc)); 2810 tctx.rdylist_act = 0; 2811 err = i40e_clear_lan_tx_queue_context(hw, i); 2812 if (err) { 2813 device_printf(dev, "Unable to clear TX context\n"); 2814 break; 2815 } 2816 err = i40e_set_lan_tx_queue_context(hw, i, &tctx); 2817 if (err) { 2818 device_printf(dev, "Unable to set TX context\n"); 2819 break; 2820 } 2821 /* Associate the ring with this PF */ 2822 txctl = I40E_QTX_CTL_PF_QUEUE; 2823 txctl |= ((hw->pf_id << I40E_QTX_CTL_PF_INDX_SHIFT) & 2824 I40E_QTX_CTL_PF_INDX_MASK); 2825 wr32(hw, I40E_QTX_CTL(i), txctl); 2826 ixl_flush(hw); 2827 2828 /* Do ring (re)init */ 2829 ixl_init_tx_ring(que); 2830 2831 /* Next setup the HMC RX Context */ 2832 if (vsi->max_frame_size <= MCLBYTES) 2833 rxr->mbuf_sz = MCLBYTES; 2834 else 2835 rxr->mbuf_sz = MJUMPAGESIZE; 2836 2837 u16 max_rxmax = rxr->mbuf_sz * hw->func_caps.rx_buf_chain_len; 2838 2839 /* Set up an RX context for the HMC */ 2840 memset(&rctx, 0, sizeof(struct i40e_hmc_obj_rxq)); 2841 rctx.dbuff = rxr->mbuf_sz >> I40E_RXQ_CTX_DBUFF_SHIFT; 2842 /* ignore header split for now */ 2843 rctx.hbuff = 0 >> I40E_RXQ_CTX_HBUFF_SHIFT; 2844 rctx.rxmax = (vsi->max_frame_size < max_rxmax) ? 2845 vsi->max_frame_size : max_rxmax; 2846 rctx.dtype = 0; 2847 rctx.dsize = 1; /* do 32byte descriptors */ 2848 rctx.hsplit_0 = 0; /* no HDR split initially */ 2849 rctx.base = (rxr->dma.pa/IXL_RX_CTX_BASE_UNITS); 2850 rctx.qlen = que->num_desc; 2851 rctx.tphrdesc_ena = 1; 2852 rctx.tphwdesc_ena = 1; 2853 rctx.tphdata_ena = 0; 2854 rctx.tphhead_ena = 0; 2855 rctx.lrxqthresh = 2; 2856 rctx.crcstrip = 1; 2857 rctx.l2tsel = 1; 2858 rctx.showiv = 1; 2859 rctx.fc_ena = 0; 2860 rctx.prefena = 1; 2861 2862 err = i40e_clear_lan_rx_queue_context(hw, i); 2863 if (err) { 2864 device_printf(dev, 2865 "Unable to clear RX context %d\n", i); 2866 break; 2867 } 2868 err = i40e_set_lan_rx_queue_context(hw, i, &rctx); 2869 if (err) { 2870 device_printf(dev, "Unable to set RX context %d\n", i); 2871 break; 2872 } 2873 err = ixl_init_rx_ring(que); 2874 if (err) { 2875 device_printf(dev, "Fail in init_rx_ring %d\n", i); 2876 break; 2877 } 2878 wr32(vsi->hw, I40E_QRX_TAIL(que->me), 0); 2879 #ifdef DEV_NETMAP 2880 /* preserve queue */ 2881 if (vsi->ifp->if_capenable & IFCAP_NETMAP) { 2882 struct netmap_adapter *na = NA(vsi->ifp); 2883 struct netmap_kring *kring = &na->rx_rings[i]; 2884 int t = na->num_rx_desc - 1 - nm_kr_rxspace(kring); 2885 wr32(vsi->hw, I40E_QRX_TAIL(que->me), t); 2886 } else 2887 #endif /* DEV_NETMAP */ 2888 wr32(vsi->hw, I40E_QRX_TAIL(que->me), que->num_desc - 1); 2889 } 2890 return (err); 2891 } 2892 2893 2894 /********************************************************************* 2895 * 2896 * Free all VSI structs. 2897 * 2898 **********************************************************************/ 2899 void 2900 ixl_free_vsi(struct ixl_vsi *vsi) 2901 { 2902 struct ixl_pf *pf = (struct ixl_pf *)vsi->back; 2903 struct ixl_queue *que = vsi->queues; 2904 2905 /* Free station queues */ 2906 for (int i = 0; i < vsi->num_queues; i++, que++) { 2907 struct tx_ring *txr = &que->txr; 2908 struct rx_ring *rxr = &que->rxr; 2909 2910 if (!mtx_initialized(&txr->mtx)) /* uninitialized */ 2911 continue; 2912 IXL_TX_LOCK(txr); 2913 ixl_free_que_tx(que); 2914 if (txr->base) 2915 i40e_free_dma_mem(&pf->hw, &txr->dma); 2916 IXL_TX_UNLOCK(txr); 2917 IXL_TX_LOCK_DESTROY(txr); 2918 2919 if (!mtx_initialized(&rxr->mtx)) /* uninitialized */ 2920 continue; 2921 IXL_RX_LOCK(rxr); 2922 ixl_free_que_rx(que); 2923 if (rxr->base) 2924 i40e_free_dma_mem(&pf->hw, &rxr->dma); 2925 IXL_RX_UNLOCK(rxr); 2926 IXL_RX_LOCK_DESTROY(rxr); 2927 2928 } 2929 free(vsi->queues, M_DEVBUF); 2930 2931 /* Free VSI filter list */ 2932 ixl_free_mac_filters(vsi); 2933 } 2934 2935 static void 2936 ixl_free_mac_filters(struct ixl_vsi *vsi) 2937 { 2938 struct ixl_mac_filter *f; 2939 2940 while (!SLIST_EMPTY(&vsi->ftl)) { 2941 f = SLIST_FIRST(&vsi->ftl); 2942 SLIST_REMOVE_HEAD(&vsi->ftl, next); 2943 free(f, M_DEVBUF); 2944 } 2945 } 2946 2947 2948 /********************************************************************* 2949 * 2950 * Allocate memory for the VSI (virtual station interface) and their 2951 * associated queues, rings and the descriptors associated with each, 2952 * called only once at attach. 2953 * 2954 **********************************************************************/ 2955 static int 2956 ixl_setup_stations(struct ixl_pf *pf) 2957 { 2958 device_t dev = pf->dev; 2959 struct ixl_vsi *vsi; 2960 struct ixl_queue *que; 2961 struct tx_ring *txr; 2962 struct rx_ring *rxr; 2963 int rsize, tsize; 2964 int error = I40E_SUCCESS; 2965 2966 vsi = &pf->vsi; 2967 vsi->back = (void *)pf; 2968 vsi->hw = &pf->hw; 2969 vsi->id = 0; 2970 vsi->num_vlans = 0; 2971 vsi->back = pf; 2972 2973 /* Get memory for the station queues */ 2974 if (!(vsi->queues = 2975 (struct ixl_queue *) malloc(sizeof(struct ixl_queue) * 2976 vsi->num_queues, M_DEVBUF, M_NOWAIT | M_ZERO))) { 2977 device_printf(dev, "Unable to allocate queue memory\n"); 2978 error = ENOMEM; 2979 goto early; 2980 } 2981 2982 for (int i = 0; i < vsi->num_queues; i++) { 2983 que = &vsi->queues[i]; 2984 que->num_desc = ixl_ringsz; 2985 que->me = i; 2986 que->vsi = vsi; 2987 /* mark the queue as active */ 2988 vsi->active_queues |= (u64)1 << que->me; 2989 txr = &que->txr; 2990 txr->que = que; 2991 txr->tail = I40E_QTX_TAIL(que->me); 2992 2993 /* Initialize the TX lock */ 2994 snprintf(txr->mtx_name, sizeof(txr->mtx_name), "%s:tx(%d)", 2995 device_get_nameunit(dev), que->me); 2996 mtx_init(&txr->mtx, txr->mtx_name, NULL, MTX_DEF); 2997 /* Create the TX descriptor ring */ 2998 tsize = roundup2((que->num_desc * 2999 sizeof(struct i40e_tx_desc)) + 3000 sizeof(u32), DBA_ALIGN); 3001 if (i40e_allocate_dma_mem(&pf->hw, 3002 &txr->dma, i40e_mem_reserved, tsize, DBA_ALIGN)) { 3003 device_printf(dev, 3004 "Unable to allocate TX Descriptor memory\n"); 3005 error = ENOMEM; 3006 goto fail; 3007 } 3008 txr->base = (struct i40e_tx_desc *)txr->dma.va; 3009 bzero((void *)txr->base, tsize); 3010 /* Now allocate transmit soft structs for the ring */ 3011 if (ixl_allocate_tx_data(que)) { 3012 device_printf(dev, 3013 "Critical Failure setting up TX structures\n"); 3014 error = ENOMEM; 3015 goto fail; 3016 } 3017 /* Allocate a buf ring */ 3018 txr->br = buf_ring_alloc(4096, M_DEVBUF, 3019 M_WAITOK, &txr->mtx); 3020 if (txr->br == NULL) { 3021 device_printf(dev, 3022 "Critical Failure setting up TX buf ring\n"); 3023 error = ENOMEM; 3024 goto fail; 3025 } 3026 3027 /* 3028 * Next the RX queues... 3029 */ 3030 rsize = roundup2(que->num_desc * 3031 sizeof(union i40e_rx_desc), DBA_ALIGN); 3032 rxr = &que->rxr; 3033 rxr->que = que; 3034 rxr->tail = I40E_QRX_TAIL(que->me); 3035 3036 /* Initialize the RX side lock */ 3037 snprintf(rxr->mtx_name, sizeof(rxr->mtx_name), "%s:rx(%d)", 3038 device_get_nameunit(dev), que->me); 3039 mtx_init(&rxr->mtx, rxr->mtx_name, NULL, MTX_DEF); 3040 3041 if (i40e_allocate_dma_mem(&pf->hw, 3042 &rxr->dma, i40e_mem_reserved, rsize, 4096)) { 3043 device_printf(dev, 3044 "Unable to allocate RX Descriptor memory\n"); 3045 error = ENOMEM; 3046 goto fail; 3047 } 3048 rxr->base = (union i40e_rx_desc *)rxr->dma.va; 3049 bzero((void *)rxr->base, rsize); 3050 3051 /* Allocate receive soft structs for the ring*/ 3052 if (ixl_allocate_rx_data(que)) { 3053 device_printf(dev, 3054 "Critical Failure setting up receive structs\n"); 3055 error = ENOMEM; 3056 goto fail; 3057 } 3058 } 3059 3060 return (0); 3061 3062 fail: 3063 for (int i = 0; i < vsi->num_queues; i++) { 3064 que = &vsi->queues[i]; 3065 rxr = &que->rxr; 3066 txr = &que->txr; 3067 if (rxr->base) 3068 i40e_free_dma_mem(&pf->hw, &rxr->dma); 3069 if (txr->base) 3070 i40e_free_dma_mem(&pf->hw, &txr->dma); 3071 } 3072 3073 early: 3074 return (error); 3075 } 3076 3077 /* 3078 ** Provide a update to the queue RX 3079 ** interrupt moderation value. 3080 */ 3081 static void 3082 ixl_set_queue_rx_itr(struct ixl_queue *que) 3083 { 3084 struct ixl_vsi *vsi = que->vsi; 3085 struct i40e_hw *hw = vsi->hw; 3086 struct rx_ring *rxr = &que->rxr; 3087 u16 rx_itr; 3088 u16 rx_latency = 0; 3089 int rx_bytes; 3090 3091 3092 /* Idle, do nothing */ 3093 if (rxr->bytes == 0) 3094 return; 3095 3096 if (ixl_dynamic_rx_itr) { 3097 rx_bytes = rxr->bytes/rxr->itr; 3098 rx_itr = rxr->itr; 3099 3100 /* Adjust latency range */ 3101 switch (rxr->latency) { 3102 case IXL_LOW_LATENCY: 3103 if (rx_bytes > 10) { 3104 rx_latency = IXL_AVE_LATENCY; 3105 rx_itr = IXL_ITR_20K; 3106 } 3107 break; 3108 case IXL_AVE_LATENCY: 3109 if (rx_bytes > 20) { 3110 rx_latency = IXL_BULK_LATENCY; 3111 rx_itr = IXL_ITR_8K; 3112 } else if (rx_bytes <= 10) { 3113 rx_latency = IXL_LOW_LATENCY; 3114 rx_itr = IXL_ITR_100K; 3115 } 3116 break; 3117 case IXL_BULK_LATENCY: 3118 if (rx_bytes <= 20) { 3119 rx_latency = IXL_AVE_LATENCY; 3120 rx_itr = IXL_ITR_20K; 3121 } 3122 break; 3123 } 3124 3125 rxr->latency = rx_latency; 3126 3127 if (rx_itr != rxr->itr) { 3128 /* do an exponential smoothing */ 3129 rx_itr = (10 * rx_itr * rxr->itr) / 3130 ((9 * rx_itr) + rxr->itr); 3131 rxr->itr = rx_itr & IXL_MAX_ITR; 3132 wr32(hw, I40E_PFINT_ITRN(IXL_RX_ITR, 3133 que->me), rxr->itr); 3134 } 3135 } else { /* We may have have toggled to non-dynamic */ 3136 if (vsi->rx_itr_setting & IXL_ITR_DYNAMIC) 3137 vsi->rx_itr_setting = ixl_rx_itr; 3138 /* Update the hardware if needed */ 3139 if (rxr->itr != vsi->rx_itr_setting) { 3140 rxr->itr = vsi->rx_itr_setting; 3141 wr32(hw, I40E_PFINT_ITRN(IXL_RX_ITR, 3142 que->me), rxr->itr); 3143 } 3144 } 3145 rxr->bytes = 0; 3146 rxr->packets = 0; 3147 return; 3148 } 3149 3150 3151 /* 3152 ** Provide a update to the queue TX 3153 ** interrupt moderation value. 3154 */ 3155 static void 3156 ixl_set_queue_tx_itr(struct ixl_queue *que) 3157 { 3158 struct ixl_vsi *vsi = que->vsi; 3159 struct i40e_hw *hw = vsi->hw; 3160 struct tx_ring *txr = &que->txr; 3161 u16 tx_itr; 3162 u16 tx_latency = 0; 3163 int tx_bytes; 3164 3165 3166 /* Idle, do nothing */ 3167 if (txr->bytes == 0) 3168 return; 3169 3170 if (ixl_dynamic_tx_itr) { 3171 tx_bytes = txr->bytes/txr->itr; 3172 tx_itr = txr->itr; 3173 3174 switch (txr->latency) { 3175 case IXL_LOW_LATENCY: 3176 if (tx_bytes > 10) { 3177 tx_latency = IXL_AVE_LATENCY; 3178 tx_itr = IXL_ITR_20K; 3179 } 3180 break; 3181 case IXL_AVE_LATENCY: 3182 if (tx_bytes > 20) { 3183 tx_latency = IXL_BULK_LATENCY; 3184 tx_itr = IXL_ITR_8K; 3185 } else if (tx_bytes <= 10) { 3186 tx_latency = IXL_LOW_LATENCY; 3187 tx_itr = IXL_ITR_100K; 3188 } 3189 break; 3190 case IXL_BULK_LATENCY: 3191 if (tx_bytes <= 20) { 3192 tx_latency = IXL_AVE_LATENCY; 3193 tx_itr = IXL_ITR_20K; 3194 } 3195 break; 3196 } 3197 3198 txr->latency = tx_latency; 3199 3200 if (tx_itr != txr->itr) { 3201 /* do an exponential smoothing */ 3202 tx_itr = (10 * tx_itr * txr->itr) / 3203 ((9 * tx_itr) + txr->itr); 3204 txr->itr = tx_itr & IXL_MAX_ITR; 3205 wr32(hw, I40E_PFINT_ITRN(IXL_TX_ITR, 3206 que->me), txr->itr); 3207 } 3208 3209 } else { /* We may have have toggled to non-dynamic */ 3210 if (vsi->tx_itr_setting & IXL_ITR_DYNAMIC) 3211 vsi->tx_itr_setting = ixl_tx_itr; 3212 /* Update the hardware if needed */ 3213 if (txr->itr != vsi->tx_itr_setting) { 3214 txr->itr = vsi->tx_itr_setting; 3215 wr32(hw, I40E_PFINT_ITRN(IXL_TX_ITR, 3216 que->me), txr->itr); 3217 } 3218 } 3219 txr->bytes = 0; 3220 txr->packets = 0; 3221 return; 3222 } 3223 3224 #define QUEUE_NAME_LEN 32 3225 3226 static void 3227 ixl_add_vsi_sysctls(struct ixl_pf *pf, struct ixl_vsi *vsi, 3228 struct sysctl_ctx_list *ctx, const char *sysctl_name) 3229 { 3230 struct sysctl_oid *tree; 3231 struct sysctl_oid_list *child; 3232 struct sysctl_oid_list *vsi_list; 3233 3234 tree = device_get_sysctl_tree(pf->dev); 3235 child = SYSCTL_CHILDREN(tree); 3236 vsi->vsi_node = SYSCTL_ADD_NODE(ctx, child, OID_AUTO, sysctl_name, 3237 CTLFLAG_RD, NULL, "VSI Number"); 3238 vsi_list = SYSCTL_CHILDREN(vsi->vsi_node); 3239 3240 ixl_add_sysctls_eth_stats(ctx, vsi_list, &vsi->eth_stats); 3241 } 3242 3243 static void 3244 ixl_add_hw_stats(struct ixl_pf *pf) 3245 { 3246 device_t dev = pf->dev; 3247 struct ixl_vsi *vsi = &pf->vsi; 3248 struct ixl_queue *queues = vsi->queues; 3249 struct i40e_hw_port_stats *pf_stats = &pf->stats; 3250 3251 struct sysctl_ctx_list *ctx = device_get_sysctl_ctx(dev); 3252 struct sysctl_oid *tree = device_get_sysctl_tree(dev); 3253 struct sysctl_oid_list *child = SYSCTL_CHILDREN(tree); 3254 struct sysctl_oid_list *vsi_list; 3255 3256 struct sysctl_oid *queue_node; 3257 struct sysctl_oid_list *queue_list; 3258 3259 struct tx_ring *txr; 3260 struct rx_ring *rxr; 3261 char queue_namebuf[QUEUE_NAME_LEN]; 3262 3263 /* Driver statistics */ 3264 SYSCTL_ADD_ULONG(ctx, child, OID_AUTO, "watchdog_events", 3265 CTLFLAG_RD, &pf->watchdog_events, 3266 "Watchdog timeouts"); 3267 SYSCTL_ADD_ULONG(ctx, child, OID_AUTO, "admin_irq", 3268 CTLFLAG_RD, &pf->admin_irq, 3269 "Admin Queue IRQ Handled"); 3270 3271 ixl_add_vsi_sysctls(pf, &pf->vsi, ctx, "pf"); 3272 vsi_list = SYSCTL_CHILDREN(pf->vsi.vsi_node); 3273 3274 /* Queue statistics */ 3275 for (int q = 0; q < vsi->num_queues; q++) { 3276 snprintf(queue_namebuf, QUEUE_NAME_LEN, "que%d", q); 3277 queue_node = SYSCTL_ADD_NODE(ctx, vsi_list, 3278 OID_AUTO, queue_namebuf, CTLFLAG_RD, NULL, "Queue #"); 3279 queue_list = SYSCTL_CHILDREN(queue_node); 3280 3281 txr = &(queues[q].txr); 3282 rxr = &(queues[q].rxr); 3283 3284 SYSCTL_ADD_UQUAD(ctx, queue_list, OID_AUTO, "mbuf_defrag_failed", 3285 CTLFLAG_RD, &(queues[q].mbuf_defrag_failed), 3286 "m_defrag() failed"); 3287 SYSCTL_ADD_UQUAD(ctx, queue_list, OID_AUTO, "dropped", 3288 CTLFLAG_RD, &(queues[q].dropped_pkts), 3289 "Driver dropped packets"); 3290 SYSCTL_ADD_UQUAD(ctx, queue_list, OID_AUTO, "irqs", 3291 CTLFLAG_RD, &(queues[q].irqs), 3292 "irqs on this queue"); 3293 SYSCTL_ADD_UQUAD(ctx, queue_list, OID_AUTO, "tso_tx", 3294 CTLFLAG_RD, &(queues[q].tso), 3295 "TSO"); 3296 SYSCTL_ADD_UQUAD(ctx, queue_list, OID_AUTO, "tx_dma_setup", 3297 CTLFLAG_RD, &(queues[q].tx_dma_setup), 3298 "Driver tx dma failure in xmit"); 3299 SYSCTL_ADD_UQUAD(ctx, queue_list, OID_AUTO, "no_desc_avail", 3300 CTLFLAG_RD, &(txr->no_desc), 3301 "Queue No Descriptor Available"); 3302 SYSCTL_ADD_UQUAD(ctx, queue_list, OID_AUTO, "tx_packets", 3303 CTLFLAG_RD, &(txr->total_packets), 3304 "Queue Packets Transmitted"); 3305 SYSCTL_ADD_UQUAD(ctx, queue_list, OID_AUTO, "tx_bytes", 3306 CTLFLAG_RD, &(txr->tx_bytes), 3307 "Queue Bytes Transmitted"); 3308 SYSCTL_ADD_UQUAD(ctx, queue_list, OID_AUTO, "rx_packets", 3309 CTLFLAG_RD, &(rxr->rx_packets), 3310 "Queue Packets Received"); 3311 SYSCTL_ADD_UQUAD(ctx, queue_list, OID_AUTO, "rx_bytes", 3312 CTLFLAG_RD, &(rxr->rx_bytes), 3313 "Queue Bytes Received"); 3314 } 3315 3316 /* MAC stats */ 3317 ixl_add_sysctls_mac_stats(ctx, child, pf_stats); 3318 } 3319 3320 static void 3321 ixl_add_sysctls_eth_stats(struct sysctl_ctx_list *ctx, 3322 struct sysctl_oid_list *child, 3323 struct i40e_eth_stats *eth_stats) 3324 { 3325 struct ixl_sysctl_info ctls[] = 3326 { 3327 {ð_stats->rx_bytes, "good_octets_rcvd", "Good Octets Received"}, 3328 {ð_stats->rx_unicast, "ucast_pkts_rcvd", 3329 "Unicast Packets Received"}, 3330 {ð_stats->rx_multicast, "mcast_pkts_rcvd", 3331 "Multicast Packets Received"}, 3332 {ð_stats->rx_broadcast, "bcast_pkts_rcvd", 3333 "Broadcast Packets Received"}, 3334 {ð_stats->rx_discards, "rx_discards", "Discarded RX packets"}, 3335 {ð_stats->tx_bytes, "good_octets_txd", "Good Octets Transmitted"}, 3336 {ð_stats->tx_unicast, "ucast_pkts_txd", "Unicast Packets Transmitted"}, 3337 {ð_stats->tx_multicast, "mcast_pkts_txd", 3338 "Multicast Packets Transmitted"}, 3339 {ð_stats->tx_broadcast, "bcast_pkts_txd", 3340 "Broadcast Packets Transmitted"}, 3341 // end 3342 {0,0,0} 3343 }; 3344 3345 struct ixl_sysctl_info *entry = ctls; 3346 while (entry->stat != 0) 3347 { 3348 SYSCTL_ADD_UQUAD(ctx, child, OID_AUTO, entry->name, 3349 CTLFLAG_RD, entry->stat, 3350 entry->description); 3351 entry++; 3352 } 3353 } 3354 3355 static void 3356 ixl_add_sysctls_mac_stats(struct sysctl_ctx_list *ctx, 3357 struct sysctl_oid_list *child, 3358 struct i40e_hw_port_stats *stats) 3359 { 3360 struct sysctl_oid *stat_node = SYSCTL_ADD_NODE(ctx, child, OID_AUTO, "mac", 3361 CTLFLAG_RD, NULL, "Mac Statistics"); 3362 struct sysctl_oid_list *stat_list = SYSCTL_CHILDREN(stat_node); 3363 3364 struct i40e_eth_stats *eth_stats = &stats->eth; 3365 ixl_add_sysctls_eth_stats(ctx, stat_list, eth_stats); 3366 3367 struct ixl_sysctl_info ctls[] = 3368 { 3369 {&stats->crc_errors, "crc_errors", "CRC Errors"}, 3370 {&stats->illegal_bytes, "illegal_bytes", "Illegal Byte Errors"}, 3371 {&stats->mac_local_faults, "local_faults", "MAC Local Faults"}, 3372 {&stats->mac_remote_faults, "remote_faults", "MAC Remote Faults"}, 3373 {&stats->rx_length_errors, "rx_length_errors", "Receive Length Errors"}, 3374 /* Packet Reception Stats */ 3375 {&stats->rx_size_64, "rx_frames_64", "64 byte frames received"}, 3376 {&stats->rx_size_127, "rx_frames_65_127", "65-127 byte frames received"}, 3377 {&stats->rx_size_255, "rx_frames_128_255", "128-255 byte frames received"}, 3378 {&stats->rx_size_511, "rx_frames_256_511", "256-511 byte frames received"}, 3379 {&stats->rx_size_1023, "rx_frames_512_1023", "512-1023 byte frames received"}, 3380 {&stats->rx_size_1522, "rx_frames_1024_1522", "1024-1522 byte frames received"}, 3381 {&stats->rx_size_big, "rx_frames_big", "1523-9522 byte frames received"}, 3382 {&stats->rx_undersize, "rx_undersize", "Undersized packets received"}, 3383 {&stats->rx_fragments, "rx_fragmented", "Fragmented packets received"}, 3384 {&stats->rx_oversize, "rx_oversized", "Oversized packets received"}, 3385 {&stats->rx_jabber, "rx_jabber", "Received Jabber"}, 3386 {&stats->checksum_error, "checksum_errors", "Checksum Errors"}, 3387 /* Packet Transmission Stats */ 3388 {&stats->tx_size_64, "tx_frames_64", "64 byte frames transmitted"}, 3389 {&stats->tx_size_127, "tx_frames_65_127", "65-127 byte frames transmitted"}, 3390 {&stats->tx_size_255, "tx_frames_128_255", "128-255 byte frames transmitted"}, 3391 {&stats->tx_size_511, "tx_frames_256_511", "256-511 byte frames transmitted"}, 3392 {&stats->tx_size_1023, "tx_frames_512_1023", "512-1023 byte frames transmitted"}, 3393 {&stats->tx_size_1522, "tx_frames_1024_1522", "1024-1522 byte frames transmitted"}, 3394 {&stats->tx_size_big, "tx_frames_big", "1523-9522 byte frames transmitted"}, 3395 /* Flow control */ 3396 {&stats->link_xon_tx, "xon_txd", "Link XON transmitted"}, 3397 {&stats->link_xon_rx, "xon_recvd", "Link XON received"}, 3398 {&stats->link_xoff_tx, "xoff_txd", "Link XOFF transmitted"}, 3399 {&stats->link_xoff_rx, "xoff_recvd", "Link XOFF received"}, 3400 /* End */ 3401 {0,0,0} 3402 }; 3403 3404 struct ixl_sysctl_info *entry = ctls; 3405 while (entry->stat != 0) 3406 { 3407 SYSCTL_ADD_UQUAD(ctx, stat_list, OID_AUTO, entry->name, 3408 CTLFLAG_RD, entry->stat, 3409 entry->description); 3410 entry++; 3411 } 3412 } 3413 3414 3415 /* 3416 ** ixl_config_rss - setup RSS 3417 ** - note this is done for the single vsi 3418 */ 3419 static void ixl_config_rss(struct ixl_vsi *vsi) 3420 { 3421 struct ixl_pf *pf = (struct ixl_pf *)vsi->back; 3422 struct i40e_hw *hw = vsi->hw; 3423 u32 lut = 0; 3424 u64 set_hena = 0, hena; 3425 int i, j, que_id; 3426 #ifdef RSS 3427 u32 rss_hash_config; 3428 u32 rss_seed[IXL_KEYSZ]; 3429 #else 3430 u32 rss_seed[IXL_KEYSZ] = {0x41b01687, 3431 0x183cfd8c, 0xce880440, 0x580cbc3c, 3432 0x35897377, 0x328b25e1, 0x4fa98922, 3433 0xb7d90c14, 0xd5bad70d, 0xcd15a2c1}; 3434 #endif 3435 3436 #ifdef RSS 3437 /* Fetch the configured RSS key */ 3438 rss_getkey((uint8_t *) &rss_seed); 3439 #endif 3440 3441 /* Fill out hash function seed */ 3442 for (i = 0; i < IXL_KEYSZ; i++) 3443 wr32(hw, I40E_PFQF_HKEY(i), rss_seed[i]); 3444 3445 /* Enable PCTYPES for RSS: */ 3446 #ifdef RSS 3447 rss_hash_config = rss_gethashconfig(); 3448 if (rss_hash_config & RSS_HASHTYPE_RSS_IPV4) 3449 set_hena |= ((u64)1 << I40E_FILTER_PCTYPE_NONF_IPV4_OTHER); 3450 if (rss_hash_config & RSS_HASHTYPE_RSS_TCP_IPV4) 3451 set_hena |= ((u64)1 << I40E_FILTER_PCTYPE_NONF_IPV4_TCP); 3452 if (rss_hash_config & RSS_HASHTYPE_RSS_UDP_IPV4) 3453 set_hena |= ((u64)1 << I40E_FILTER_PCTYPE_NONF_IPV4_UDP); 3454 if (rss_hash_config & RSS_HASHTYPE_RSS_IPV6) 3455 set_hena |= ((u64)1 << I40E_FILTER_PCTYPE_NONF_IPV6_OTHER); 3456 if (rss_hash_config & RSS_HASHTYPE_RSS_IPV6_EX) 3457 set_hena |= ((u64)1 << I40E_FILTER_PCTYPE_FRAG_IPV6); 3458 if (rss_hash_config & RSS_HASHTYPE_RSS_TCP_IPV6) 3459 set_hena |= ((u64)1 << I40E_FILTER_PCTYPE_NONF_IPV6_TCP); 3460 if (rss_hash_config & RSS_HASHTYPE_RSS_UDP_IPV6) 3461 set_hena |= ((u64)1 << I40E_FILTER_PCTYPE_NONF_IPV6_UDP); 3462 #else 3463 set_hena = 3464 ((u64)1 << I40E_FILTER_PCTYPE_NONF_IPV4_UDP) | 3465 ((u64)1 << I40E_FILTER_PCTYPE_NONF_IPV4_TCP) | 3466 ((u64)1 << I40E_FILTER_PCTYPE_NONF_IPV4_SCTP) | 3467 ((u64)1 << I40E_FILTER_PCTYPE_NONF_IPV4_OTHER) | 3468 ((u64)1 << I40E_FILTER_PCTYPE_FRAG_IPV4) | 3469 ((u64)1 << I40E_FILTER_PCTYPE_NONF_IPV6_UDP) | 3470 ((u64)1 << I40E_FILTER_PCTYPE_NONF_IPV6_TCP) | 3471 ((u64)1 << I40E_FILTER_PCTYPE_NONF_IPV6_SCTP) | 3472 ((u64)1 << I40E_FILTER_PCTYPE_NONF_IPV6_OTHER) | 3473 ((u64)1 << I40E_FILTER_PCTYPE_FRAG_IPV6) | 3474 ((u64)1 << I40E_FILTER_PCTYPE_L2_PAYLOAD); 3475 #endif 3476 hena = (u64)rd32(hw, I40E_PFQF_HENA(0)) | 3477 ((u64)rd32(hw, I40E_PFQF_HENA(1)) << 32); 3478 hena |= set_hena; 3479 wr32(hw, I40E_PFQF_HENA(0), (u32)hena); 3480 wr32(hw, I40E_PFQF_HENA(1), (u32)(hena >> 32)); 3481 3482 /* Populate the LUT with max no. of queues in round robin fashion */ 3483 for (i = j = 0; i < pf->hw.func_caps.rss_table_size; i++, j++) { 3484 if (j == vsi->num_queues) 3485 j = 0; 3486 #ifdef RSS 3487 /* 3488 * Fetch the RSS bucket id for the given indirection entry. 3489 * Cap it at the number of configured buckets (which is 3490 * num_queues.) 3491 */ 3492 que_id = rss_get_indirection_to_bucket(i); 3493 que_id = que_id % vsi->num_queues; 3494 #else 3495 que_id = j; 3496 #endif 3497 /* lut = 4-byte sliding window of 4 lut entries */ 3498 lut = (lut << 8) | (que_id & 3499 ((0x1 << pf->hw.func_caps.rss_table_entry_width) - 1)); 3500 /* On i = 3, we have 4 entries in lut; write to the register */ 3501 if ((i & 3) == 3) 3502 wr32(hw, I40E_PFQF_HLUT(i >> 2), lut); 3503 } 3504 ixl_flush(hw); 3505 } 3506 3507 3508 /* 3509 ** This routine is run via an vlan config EVENT, 3510 ** it enables us to use the HW Filter table since 3511 ** we can get the vlan id. This just creates the 3512 ** entry in the soft version of the VFTA, init will 3513 ** repopulate the real table. 3514 */ 3515 static void 3516 ixl_register_vlan(void *arg, struct ifnet *ifp, u16 vtag) 3517 { 3518 struct ixl_vsi *vsi = ifp->if_softc; 3519 struct i40e_hw *hw = vsi->hw; 3520 struct ixl_pf *pf = (struct ixl_pf *)vsi->back; 3521 3522 if (ifp->if_softc != arg) /* Not our event */ 3523 return; 3524 3525 if ((vtag == 0) || (vtag > 4095)) /* Invalid */ 3526 return; 3527 3528 IXL_PF_LOCK(pf); 3529 ++vsi->num_vlans; 3530 ixl_add_filter(vsi, hw->mac.addr, vtag); 3531 IXL_PF_UNLOCK(pf); 3532 } 3533 3534 /* 3535 ** This routine is run via an vlan 3536 ** unconfig EVENT, remove our entry 3537 ** in the soft vfta. 3538 */ 3539 static void 3540 ixl_unregister_vlan(void *arg, struct ifnet *ifp, u16 vtag) 3541 { 3542 struct ixl_vsi *vsi = ifp->if_softc; 3543 struct i40e_hw *hw = vsi->hw; 3544 struct ixl_pf *pf = (struct ixl_pf *)vsi->back; 3545 3546 if (ifp->if_softc != arg) 3547 return; 3548 3549 if ((vtag == 0) || (vtag > 4095)) /* Invalid */ 3550 return; 3551 3552 IXL_PF_LOCK(pf); 3553 --vsi->num_vlans; 3554 ixl_del_filter(vsi, hw->mac.addr, vtag); 3555 IXL_PF_UNLOCK(pf); 3556 } 3557 3558 /* 3559 ** This routine updates vlan filters, called by init 3560 ** it scans the filter table and then updates the hw 3561 ** after a soft reset. 3562 */ 3563 static void 3564 ixl_setup_vlan_filters(struct ixl_vsi *vsi) 3565 { 3566 struct ixl_mac_filter *f; 3567 int cnt = 0, flags; 3568 3569 if (vsi->num_vlans == 0) 3570 return; 3571 /* 3572 ** Scan the filter list for vlan entries, 3573 ** mark them for addition and then call 3574 ** for the AQ update. 3575 */ 3576 SLIST_FOREACH(f, &vsi->ftl, next) { 3577 if (f->flags & IXL_FILTER_VLAN) { 3578 f->flags |= 3579 (IXL_FILTER_ADD | 3580 IXL_FILTER_USED); 3581 cnt++; 3582 } 3583 } 3584 if (cnt == 0) { 3585 printf("setup vlan: no filters found!\n"); 3586 return; 3587 } 3588 flags = IXL_FILTER_VLAN; 3589 flags |= (IXL_FILTER_ADD | IXL_FILTER_USED); 3590 ixl_add_hw_filters(vsi, flags, cnt); 3591 return; 3592 } 3593 3594 /* 3595 ** Initialize filter list and add filters that the hardware 3596 ** needs to know about. 3597 */ 3598 static void 3599 ixl_init_filters(struct ixl_vsi *vsi) 3600 { 3601 /* Add broadcast address */ 3602 ixl_add_filter(vsi, ixl_bcast_addr, IXL_VLAN_ANY); 3603 } 3604 3605 /* 3606 ** This routine adds mulicast filters 3607 */ 3608 static void 3609 ixl_add_mc_filter(struct ixl_vsi *vsi, u8 *macaddr) 3610 { 3611 struct ixl_mac_filter *f; 3612 3613 /* Does one already exist */ 3614 f = ixl_find_filter(vsi, macaddr, IXL_VLAN_ANY); 3615 if (f != NULL) 3616 return; 3617 3618 f = ixl_get_filter(vsi); 3619 if (f == NULL) { 3620 printf("WARNING: no filter available!!\n"); 3621 return; 3622 } 3623 bcopy(macaddr, f->macaddr, ETHER_ADDR_LEN); 3624 f->vlan = IXL_VLAN_ANY; 3625 f->flags |= (IXL_FILTER_ADD | IXL_FILTER_USED 3626 | IXL_FILTER_MC); 3627 3628 return; 3629 } 3630 3631 static void 3632 ixl_reconfigure_filters(struct ixl_vsi *vsi) 3633 { 3634 3635 ixl_add_hw_filters(vsi, IXL_FILTER_USED, vsi->num_macs); 3636 } 3637 3638 /* 3639 ** This routine adds macvlan filters 3640 */ 3641 static void 3642 ixl_add_filter(struct ixl_vsi *vsi, u8 *macaddr, s16 vlan) 3643 { 3644 struct ixl_mac_filter *f, *tmp; 3645 struct ixl_pf *pf; 3646 device_t dev; 3647 3648 DEBUGOUT("ixl_add_filter: begin"); 3649 3650 pf = vsi->back; 3651 dev = pf->dev; 3652 3653 /* Does one already exist */ 3654 f = ixl_find_filter(vsi, macaddr, vlan); 3655 if (f != NULL) 3656 return; 3657 /* 3658 ** Is this the first vlan being registered, if so we 3659 ** need to remove the ANY filter that indicates we are 3660 ** not in a vlan, and replace that with a 0 filter. 3661 */ 3662 if ((vlan != IXL_VLAN_ANY) && (vsi->num_vlans == 1)) { 3663 tmp = ixl_find_filter(vsi, macaddr, IXL_VLAN_ANY); 3664 if (tmp != NULL) { 3665 ixl_del_filter(vsi, macaddr, IXL_VLAN_ANY); 3666 ixl_add_filter(vsi, macaddr, 0); 3667 } 3668 } 3669 3670 f = ixl_get_filter(vsi); 3671 if (f == NULL) { 3672 device_printf(dev, "WARNING: no filter available!!\n"); 3673 return; 3674 } 3675 bcopy(macaddr, f->macaddr, ETHER_ADDR_LEN); 3676 f->vlan = vlan; 3677 f->flags |= (IXL_FILTER_ADD | IXL_FILTER_USED); 3678 if (f->vlan != IXL_VLAN_ANY) 3679 f->flags |= IXL_FILTER_VLAN; 3680 else 3681 vsi->num_macs++; 3682 3683 ixl_add_hw_filters(vsi, f->flags, 1); 3684 return; 3685 } 3686 3687 static void 3688 ixl_del_filter(struct ixl_vsi *vsi, u8 *macaddr, s16 vlan) 3689 { 3690 struct ixl_mac_filter *f; 3691 3692 f = ixl_find_filter(vsi, macaddr, vlan); 3693 if (f == NULL) 3694 return; 3695 3696 f->flags |= IXL_FILTER_DEL; 3697 ixl_del_hw_filters(vsi, 1); 3698 vsi->num_macs--; 3699 3700 /* Check if this is the last vlan removal */ 3701 if (vlan != IXL_VLAN_ANY && vsi->num_vlans == 0) { 3702 /* Switch back to a non-vlan filter */ 3703 ixl_del_filter(vsi, macaddr, 0); 3704 ixl_add_filter(vsi, macaddr, IXL_VLAN_ANY); 3705 } 3706 return; 3707 } 3708 3709 /* 3710 ** Find the filter with both matching mac addr and vlan id 3711 */ 3712 static struct ixl_mac_filter * 3713 ixl_find_filter(struct ixl_vsi *vsi, u8 *macaddr, s16 vlan) 3714 { 3715 struct ixl_mac_filter *f; 3716 bool match = FALSE; 3717 3718 SLIST_FOREACH(f, &vsi->ftl, next) { 3719 if (!cmp_etheraddr(f->macaddr, macaddr)) 3720 continue; 3721 if (f->vlan == vlan) { 3722 match = TRUE; 3723 break; 3724 } 3725 } 3726 3727 if (!match) 3728 f = NULL; 3729 return (f); 3730 } 3731 3732 /* 3733 ** This routine takes additions to the vsi filter 3734 ** table and creates an Admin Queue call to create 3735 ** the filters in the hardware. 3736 */ 3737 static void 3738 ixl_add_hw_filters(struct ixl_vsi *vsi, int flags, int cnt) 3739 { 3740 struct i40e_aqc_add_macvlan_element_data *a, *b; 3741 struct ixl_mac_filter *f; 3742 struct ixl_pf *pf; 3743 struct i40e_hw *hw; 3744 device_t dev; 3745 int err, j = 0; 3746 3747 pf = vsi->back; 3748 dev = pf->dev; 3749 hw = &pf->hw; 3750 IXL_PF_LOCK_ASSERT(pf); 3751 3752 a = malloc(sizeof(struct i40e_aqc_add_macvlan_element_data) * cnt, 3753 M_DEVBUF, M_NOWAIT | M_ZERO); 3754 if (a == NULL) { 3755 device_printf(dev, "add_hw_filters failed to get memory\n"); 3756 return; 3757 } 3758 3759 /* 3760 ** Scan the filter list, each time we find one 3761 ** we add it to the admin queue array and turn off 3762 ** the add bit. 3763 */ 3764 SLIST_FOREACH(f, &vsi->ftl, next) { 3765 if (f->flags == flags) { 3766 b = &a[j]; // a pox on fvl long names :) 3767 bcopy(f->macaddr, b->mac_addr, ETHER_ADDR_LEN); 3768 if (f->vlan == IXL_VLAN_ANY) { 3769 b->vlan_tag = 0; 3770 b->flags = I40E_AQC_MACVLAN_ADD_IGNORE_VLAN; 3771 } else { 3772 b->vlan_tag = f->vlan; 3773 b->flags = 0; 3774 } 3775 b->flags |= I40E_AQC_MACVLAN_ADD_PERFECT_MATCH; 3776 f->flags &= ~IXL_FILTER_ADD; 3777 j++; 3778 } 3779 if (j == cnt) 3780 break; 3781 } 3782 if (j > 0) { 3783 err = i40e_aq_add_macvlan(hw, vsi->seid, a, j, NULL); 3784 if (err) 3785 device_printf(dev, "aq_add_macvlan err %d, " 3786 "aq_error %d\n", err, hw->aq.asq_last_status); 3787 else 3788 vsi->hw_filters_add += j; 3789 } 3790 free(a, M_DEVBUF); 3791 return; 3792 } 3793 3794 /* 3795 ** This routine takes removals in the vsi filter 3796 ** table and creates an Admin Queue call to delete 3797 ** the filters in the hardware. 3798 */ 3799 static void 3800 ixl_del_hw_filters(struct ixl_vsi *vsi, int cnt) 3801 { 3802 struct i40e_aqc_remove_macvlan_element_data *d, *e; 3803 struct ixl_pf *pf; 3804 struct i40e_hw *hw; 3805 device_t dev; 3806 struct ixl_mac_filter *f, *f_temp; 3807 int err, j = 0; 3808 3809 DEBUGOUT("ixl_del_hw_filters: begin\n"); 3810 3811 pf = vsi->back; 3812 hw = &pf->hw; 3813 dev = pf->dev; 3814 3815 d = malloc(sizeof(struct i40e_aqc_remove_macvlan_element_data) * cnt, 3816 M_DEVBUF, M_NOWAIT | M_ZERO); 3817 if (d == NULL) { 3818 printf("del hw filter failed to get memory\n"); 3819 return; 3820 } 3821 3822 SLIST_FOREACH_SAFE(f, &vsi->ftl, next, f_temp) { 3823 if (f->flags & IXL_FILTER_DEL) { 3824 e = &d[j]; // a pox on fvl long names :) 3825 bcopy(f->macaddr, e->mac_addr, ETHER_ADDR_LEN); 3826 e->vlan_tag = (f->vlan == IXL_VLAN_ANY ? 0 : f->vlan); 3827 e->flags = I40E_AQC_MACVLAN_DEL_PERFECT_MATCH; 3828 /* delete entry from vsi list */ 3829 SLIST_REMOVE(&vsi->ftl, f, ixl_mac_filter, next); 3830 free(f, M_DEVBUF); 3831 j++; 3832 } 3833 if (j == cnt) 3834 break; 3835 } 3836 if (j > 0) { 3837 err = i40e_aq_remove_macvlan(hw, vsi->seid, d, j, NULL); 3838 /* NOTE: returns ENOENT every time but seems to work fine, 3839 so we'll ignore that specific error. */ 3840 // TODO: Does this still occur on current firmwares? 3841 if (err && hw->aq.asq_last_status != I40E_AQ_RC_ENOENT) { 3842 int sc = 0; 3843 for (int i = 0; i < j; i++) 3844 sc += (!d[i].error_code); 3845 vsi->hw_filters_del += sc; 3846 device_printf(dev, 3847 "Failed to remove %d/%d filters, aq error %d\n", 3848 j - sc, j, hw->aq.asq_last_status); 3849 } else 3850 vsi->hw_filters_del += j; 3851 } 3852 free(d, M_DEVBUF); 3853 3854 DEBUGOUT("ixl_del_hw_filters: end\n"); 3855 return; 3856 } 3857 3858 static int 3859 ixl_enable_rings(struct ixl_vsi *vsi) 3860 { 3861 struct ixl_pf *pf = vsi->back; 3862 struct i40e_hw *hw = &pf->hw; 3863 int index, error; 3864 u32 reg; 3865 3866 error = 0; 3867 for (int i = 0; i < vsi->num_queues; i++) { 3868 index = vsi->first_queue + i; 3869 i40e_pre_tx_queue_cfg(hw, index, TRUE); 3870 3871 reg = rd32(hw, I40E_QTX_ENA(index)); 3872 reg |= I40E_QTX_ENA_QENA_REQ_MASK | 3873 I40E_QTX_ENA_QENA_STAT_MASK; 3874 wr32(hw, I40E_QTX_ENA(index), reg); 3875 /* Verify the enable took */ 3876 for (int j = 0; j < 10; j++) { 3877 reg = rd32(hw, I40E_QTX_ENA(index)); 3878 if (reg & I40E_QTX_ENA_QENA_STAT_MASK) 3879 break; 3880 i40e_msec_delay(10); 3881 } 3882 if ((reg & I40E_QTX_ENA_QENA_STAT_MASK) == 0) { 3883 device_printf(pf->dev, "TX queue %d disabled!\n", 3884 index); 3885 error = ETIMEDOUT; 3886 } 3887 3888 reg = rd32(hw, I40E_QRX_ENA(index)); 3889 reg |= I40E_QRX_ENA_QENA_REQ_MASK | 3890 I40E_QRX_ENA_QENA_STAT_MASK; 3891 wr32(hw, I40E_QRX_ENA(index), reg); 3892 /* Verify the enable took */ 3893 for (int j = 0; j < 10; j++) { 3894 reg = rd32(hw, I40E_QRX_ENA(index)); 3895 if (reg & I40E_QRX_ENA_QENA_STAT_MASK) 3896 break; 3897 i40e_msec_delay(10); 3898 } 3899 if ((reg & I40E_QRX_ENA_QENA_STAT_MASK) == 0) { 3900 device_printf(pf->dev, "RX queue %d disabled!\n", 3901 index); 3902 error = ETIMEDOUT; 3903 } 3904 } 3905 3906 return (error); 3907 } 3908 3909 static int 3910 ixl_disable_rings(struct ixl_vsi *vsi) 3911 { 3912 struct ixl_pf *pf = vsi->back; 3913 struct i40e_hw *hw = &pf->hw; 3914 int index, error; 3915 u32 reg; 3916 3917 error = 0; 3918 for (int i = 0; i < vsi->num_queues; i++) { 3919 index = vsi->first_queue + i; 3920 3921 i40e_pre_tx_queue_cfg(hw, index, FALSE); 3922 i40e_usec_delay(500); 3923 3924 reg = rd32(hw, I40E_QTX_ENA(index)); 3925 reg &= ~I40E_QTX_ENA_QENA_REQ_MASK; 3926 wr32(hw, I40E_QTX_ENA(index), reg); 3927 /* Verify the disable took */ 3928 for (int j = 0; j < 10; j++) { 3929 reg = rd32(hw, I40E_QTX_ENA(index)); 3930 if (!(reg & I40E_QTX_ENA_QENA_STAT_MASK)) 3931 break; 3932 i40e_msec_delay(10); 3933 } 3934 if (reg & I40E_QTX_ENA_QENA_STAT_MASK) { 3935 device_printf(pf->dev, "TX queue %d still enabled!\n", 3936 index); 3937 error = ETIMEDOUT; 3938 } 3939 3940 reg = rd32(hw, I40E_QRX_ENA(index)); 3941 reg &= ~I40E_QRX_ENA_QENA_REQ_MASK; 3942 wr32(hw, I40E_QRX_ENA(index), reg); 3943 /* Verify the disable took */ 3944 for (int j = 0; j < 10; j++) { 3945 reg = rd32(hw, I40E_QRX_ENA(index)); 3946 if (!(reg & I40E_QRX_ENA_QENA_STAT_MASK)) 3947 break; 3948 i40e_msec_delay(10); 3949 } 3950 if (reg & I40E_QRX_ENA_QENA_STAT_MASK) { 3951 device_printf(pf->dev, "RX queue %d still enabled!\n", 3952 index); 3953 error = ETIMEDOUT; 3954 } 3955 } 3956 3957 return (error); 3958 } 3959 3960 /** 3961 * ixl_handle_mdd_event 3962 * 3963 * Called from interrupt handler to identify possibly malicious vfs 3964 * (But also detects events from the PF, as well) 3965 **/ 3966 static void ixl_handle_mdd_event(struct ixl_pf *pf) 3967 { 3968 struct i40e_hw *hw = &pf->hw; 3969 device_t dev = pf->dev; 3970 bool mdd_detected = false; 3971 bool pf_mdd_detected = false; 3972 u32 reg; 3973 3974 /* find what triggered the MDD event */ 3975 reg = rd32(hw, I40E_GL_MDET_TX); 3976 if (reg & I40E_GL_MDET_TX_VALID_MASK) { 3977 u8 pf_num = (reg & I40E_GL_MDET_TX_PF_NUM_MASK) >> 3978 I40E_GL_MDET_TX_PF_NUM_SHIFT; 3979 u8 event = (reg & I40E_GL_MDET_TX_EVENT_MASK) >> 3980 I40E_GL_MDET_TX_EVENT_SHIFT; 3981 u8 queue = (reg & I40E_GL_MDET_TX_QUEUE_MASK) >> 3982 I40E_GL_MDET_TX_QUEUE_SHIFT; 3983 device_printf(dev, 3984 "Malicious Driver Detection event 0x%02x" 3985 " on TX queue %d pf number 0x%02x\n", 3986 event, queue, pf_num); 3987 wr32(hw, I40E_GL_MDET_TX, 0xffffffff); 3988 mdd_detected = true; 3989 } 3990 reg = rd32(hw, I40E_GL_MDET_RX); 3991 if (reg & I40E_GL_MDET_RX_VALID_MASK) { 3992 u8 func = (reg & I40E_GL_MDET_RX_FUNCTION_MASK) >> 3993 I40E_GL_MDET_RX_FUNCTION_SHIFT; 3994 u8 event = (reg & I40E_GL_MDET_RX_EVENT_MASK) >> 3995 I40E_GL_MDET_RX_EVENT_SHIFT; 3996 u8 queue = (reg & I40E_GL_MDET_RX_QUEUE_MASK) >> 3997 I40E_GL_MDET_RX_QUEUE_SHIFT; 3998 device_printf(dev, 3999 "Malicious Driver Detection event 0x%02x" 4000 " on RX queue %d of function 0x%02x\n", 4001 event, queue, func); 4002 wr32(hw, I40E_GL_MDET_RX, 0xffffffff); 4003 mdd_detected = true; 4004 } 4005 4006 if (mdd_detected) { 4007 reg = rd32(hw, I40E_PF_MDET_TX); 4008 if (reg & I40E_PF_MDET_TX_VALID_MASK) { 4009 wr32(hw, I40E_PF_MDET_TX, 0xFFFF); 4010 device_printf(dev, 4011 "MDD TX event is for this function 0x%08x", 4012 reg); 4013 pf_mdd_detected = true; 4014 } 4015 reg = rd32(hw, I40E_PF_MDET_RX); 4016 if (reg & I40E_PF_MDET_RX_VALID_MASK) { 4017 wr32(hw, I40E_PF_MDET_RX, 0xFFFF); 4018 device_printf(dev, 4019 "MDD RX event is for this function 0x%08x", 4020 reg); 4021 pf_mdd_detected = true; 4022 } 4023 } 4024 4025 /* re-enable mdd interrupt cause */ 4026 reg = rd32(hw, I40E_PFINT_ICR0_ENA); 4027 reg |= I40E_PFINT_ICR0_ENA_MAL_DETECT_MASK; 4028 wr32(hw, I40E_PFINT_ICR0_ENA, reg); 4029 ixl_flush(hw); 4030 } 4031 4032 static void 4033 ixl_enable_intr(struct ixl_vsi *vsi) 4034 { 4035 struct i40e_hw *hw = vsi->hw; 4036 struct ixl_queue *que = vsi->queues; 4037 4038 if (ixl_enable_msix) { 4039 ixl_enable_adminq(hw); 4040 for (int i = 0; i < vsi->num_queues; i++, que++) 4041 ixl_enable_queue(hw, que->me); 4042 } else 4043 ixl_enable_legacy(hw); 4044 } 4045 4046 static void 4047 ixl_disable_rings_intr(struct ixl_vsi *vsi) 4048 { 4049 struct i40e_hw *hw = vsi->hw; 4050 struct ixl_queue *que = vsi->queues; 4051 4052 for (int i = 0; i < vsi->num_queues; i++, que++) 4053 ixl_disable_queue(hw, que->me); 4054 } 4055 4056 static void 4057 ixl_disable_intr(struct ixl_vsi *vsi) 4058 { 4059 struct i40e_hw *hw = vsi->hw; 4060 4061 if (ixl_enable_msix) 4062 ixl_disable_adminq(hw); 4063 else 4064 ixl_disable_legacy(hw); 4065 } 4066 4067 static void 4068 ixl_enable_adminq(struct i40e_hw *hw) 4069 { 4070 u32 reg; 4071 4072 reg = I40E_PFINT_DYN_CTL0_INTENA_MASK | 4073 I40E_PFINT_DYN_CTL0_CLEARPBA_MASK | 4074 (IXL_ITR_NONE << I40E_PFINT_DYN_CTL0_ITR_INDX_SHIFT); 4075 wr32(hw, I40E_PFINT_DYN_CTL0, reg); 4076 ixl_flush(hw); 4077 return; 4078 } 4079 4080 static void 4081 ixl_disable_adminq(struct i40e_hw *hw) 4082 { 4083 u32 reg; 4084 4085 reg = IXL_ITR_NONE << I40E_PFINT_DYN_CTL0_ITR_INDX_SHIFT; 4086 wr32(hw, I40E_PFINT_DYN_CTL0, reg); 4087 4088 return; 4089 } 4090 4091 static void 4092 ixl_enable_queue(struct i40e_hw *hw, int id) 4093 { 4094 u32 reg; 4095 4096 reg = I40E_PFINT_DYN_CTLN_INTENA_MASK | 4097 I40E_PFINT_DYN_CTLN_CLEARPBA_MASK | 4098 (IXL_ITR_NONE << I40E_PFINT_DYN_CTLN_ITR_INDX_SHIFT); 4099 wr32(hw, I40E_PFINT_DYN_CTLN(id), reg); 4100 } 4101 4102 static void 4103 ixl_disable_queue(struct i40e_hw *hw, int id) 4104 { 4105 u32 reg; 4106 4107 reg = IXL_ITR_NONE << I40E_PFINT_DYN_CTLN_ITR_INDX_SHIFT; 4108 wr32(hw, I40E_PFINT_DYN_CTLN(id), reg); 4109 4110 return; 4111 } 4112 4113 static void 4114 ixl_enable_legacy(struct i40e_hw *hw) 4115 { 4116 u32 reg; 4117 reg = I40E_PFINT_DYN_CTL0_INTENA_MASK | 4118 I40E_PFINT_DYN_CTL0_CLEARPBA_MASK | 4119 (IXL_ITR_NONE << I40E_PFINT_DYN_CTL0_ITR_INDX_SHIFT); 4120 wr32(hw, I40E_PFINT_DYN_CTL0, reg); 4121 } 4122 4123 static void 4124 ixl_disable_legacy(struct i40e_hw *hw) 4125 { 4126 u32 reg; 4127 4128 reg = IXL_ITR_NONE << I40E_PFINT_DYN_CTL0_ITR_INDX_SHIFT; 4129 wr32(hw, I40E_PFINT_DYN_CTL0, reg); 4130 4131 return; 4132 } 4133 4134 static void 4135 ixl_update_stats_counters(struct ixl_pf *pf) 4136 { 4137 struct i40e_hw *hw = &pf->hw; 4138 struct ixl_vsi *vsi = &pf->vsi; 4139 struct ixl_vf *vf; 4140 4141 struct i40e_hw_port_stats *nsd = &pf->stats; 4142 struct i40e_hw_port_stats *osd = &pf->stats_offsets; 4143 4144 /* Update hw stats */ 4145 ixl_stat_update32(hw, I40E_GLPRT_CRCERRS(hw->port), 4146 pf->stat_offsets_loaded, 4147 &osd->crc_errors, &nsd->crc_errors); 4148 ixl_stat_update32(hw, I40E_GLPRT_ILLERRC(hw->port), 4149 pf->stat_offsets_loaded, 4150 &osd->illegal_bytes, &nsd->illegal_bytes); 4151 ixl_stat_update48(hw, I40E_GLPRT_GORCH(hw->port), 4152 I40E_GLPRT_GORCL(hw->port), 4153 pf->stat_offsets_loaded, 4154 &osd->eth.rx_bytes, &nsd->eth.rx_bytes); 4155 ixl_stat_update48(hw, I40E_GLPRT_GOTCH(hw->port), 4156 I40E_GLPRT_GOTCL(hw->port), 4157 pf->stat_offsets_loaded, 4158 &osd->eth.tx_bytes, &nsd->eth.tx_bytes); 4159 ixl_stat_update32(hw, I40E_GLPRT_RDPC(hw->port), 4160 pf->stat_offsets_loaded, 4161 &osd->eth.rx_discards, 4162 &nsd->eth.rx_discards); 4163 ixl_stat_update48(hw, I40E_GLPRT_UPRCH(hw->port), 4164 I40E_GLPRT_UPRCL(hw->port), 4165 pf->stat_offsets_loaded, 4166 &osd->eth.rx_unicast, 4167 &nsd->eth.rx_unicast); 4168 ixl_stat_update48(hw, I40E_GLPRT_UPTCH(hw->port), 4169 I40E_GLPRT_UPTCL(hw->port), 4170 pf->stat_offsets_loaded, 4171 &osd->eth.tx_unicast, 4172 &nsd->eth.tx_unicast); 4173 ixl_stat_update48(hw, I40E_GLPRT_MPRCH(hw->port), 4174 I40E_GLPRT_MPRCL(hw->port), 4175 pf->stat_offsets_loaded, 4176 &osd->eth.rx_multicast, 4177 &nsd->eth.rx_multicast); 4178 ixl_stat_update48(hw, I40E_GLPRT_MPTCH(hw->port), 4179 I40E_GLPRT_MPTCL(hw->port), 4180 pf->stat_offsets_loaded, 4181 &osd->eth.tx_multicast, 4182 &nsd->eth.tx_multicast); 4183 ixl_stat_update48(hw, I40E_GLPRT_BPRCH(hw->port), 4184 I40E_GLPRT_BPRCL(hw->port), 4185 pf->stat_offsets_loaded, 4186 &osd->eth.rx_broadcast, 4187 &nsd->eth.rx_broadcast); 4188 ixl_stat_update48(hw, I40E_GLPRT_BPTCH(hw->port), 4189 I40E_GLPRT_BPTCL(hw->port), 4190 pf->stat_offsets_loaded, 4191 &osd->eth.tx_broadcast, 4192 &nsd->eth.tx_broadcast); 4193 4194 ixl_stat_update32(hw, I40E_GLPRT_TDOLD(hw->port), 4195 pf->stat_offsets_loaded, 4196 &osd->tx_dropped_link_down, 4197 &nsd->tx_dropped_link_down); 4198 ixl_stat_update32(hw, I40E_GLPRT_MLFC(hw->port), 4199 pf->stat_offsets_loaded, 4200 &osd->mac_local_faults, 4201 &nsd->mac_local_faults); 4202 ixl_stat_update32(hw, I40E_GLPRT_MRFC(hw->port), 4203 pf->stat_offsets_loaded, 4204 &osd->mac_remote_faults, 4205 &nsd->mac_remote_faults); 4206 ixl_stat_update32(hw, I40E_GLPRT_RLEC(hw->port), 4207 pf->stat_offsets_loaded, 4208 &osd->rx_length_errors, 4209 &nsd->rx_length_errors); 4210 4211 /* Flow control (LFC) stats */ 4212 ixl_stat_update32(hw, I40E_GLPRT_LXONRXC(hw->port), 4213 pf->stat_offsets_loaded, 4214 &osd->link_xon_rx, &nsd->link_xon_rx); 4215 ixl_stat_update32(hw, I40E_GLPRT_LXONTXC(hw->port), 4216 pf->stat_offsets_loaded, 4217 &osd->link_xon_tx, &nsd->link_xon_tx); 4218 ixl_stat_update32(hw, I40E_GLPRT_LXOFFRXC(hw->port), 4219 pf->stat_offsets_loaded, 4220 &osd->link_xoff_rx, &nsd->link_xoff_rx); 4221 ixl_stat_update32(hw, I40E_GLPRT_LXOFFTXC(hw->port), 4222 pf->stat_offsets_loaded, 4223 &osd->link_xoff_tx, &nsd->link_xoff_tx); 4224 4225 /* Packet size stats rx */ 4226 ixl_stat_update48(hw, I40E_GLPRT_PRC64H(hw->port), 4227 I40E_GLPRT_PRC64L(hw->port), 4228 pf->stat_offsets_loaded, 4229 &osd->rx_size_64, &nsd->rx_size_64); 4230 ixl_stat_update48(hw, I40E_GLPRT_PRC127H(hw->port), 4231 I40E_GLPRT_PRC127L(hw->port), 4232 pf->stat_offsets_loaded, 4233 &osd->rx_size_127, &nsd->rx_size_127); 4234 ixl_stat_update48(hw, I40E_GLPRT_PRC255H(hw->port), 4235 I40E_GLPRT_PRC255L(hw->port), 4236 pf->stat_offsets_loaded, 4237 &osd->rx_size_255, &nsd->rx_size_255); 4238 ixl_stat_update48(hw, I40E_GLPRT_PRC511H(hw->port), 4239 I40E_GLPRT_PRC511L(hw->port), 4240 pf->stat_offsets_loaded, 4241 &osd->rx_size_511, &nsd->rx_size_511); 4242 ixl_stat_update48(hw, I40E_GLPRT_PRC1023H(hw->port), 4243 I40E_GLPRT_PRC1023L(hw->port), 4244 pf->stat_offsets_loaded, 4245 &osd->rx_size_1023, &nsd->rx_size_1023); 4246 ixl_stat_update48(hw, I40E_GLPRT_PRC1522H(hw->port), 4247 I40E_GLPRT_PRC1522L(hw->port), 4248 pf->stat_offsets_loaded, 4249 &osd->rx_size_1522, &nsd->rx_size_1522); 4250 ixl_stat_update48(hw, I40E_GLPRT_PRC9522H(hw->port), 4251 I40E_GLPRT_PRC9522L(hw->port), 4252 pf->stat_offsets_loaded, 4253 &osd->rx_size_big, &nsd->rx_size_big); 4254 4255 /* Packet size stats tx */ 4256 ixl_stat_update48(hw, I40E_GLPRT_PTC64H(hw->port), 4257 I40E_GLPRT_PTC64L(hw->port), 4258 pf->stat_offsets_loaded, 4259 &osd->tx_size_64, &nsd->tx_size_64); 4260 ixl_stat_update48(hw, I40E_GLPRT_PTC127H(hw->port), 4261 I40E_GLPRT_PTC127L(hw->port), 4262 pf->stat_offsets_loaded, 4263 &osd->tx_size_127, &nsd->tx_size_127); 4264 ixl_stat_update48(hw, I40E_GLPRT_PTC255H(hw->port), 4265 I40E_GLPRT_PTC255L(hw->port), 4266 pf->stat_offsets_loaded, 4267 &osd->tx_size_255, &nsd->tx_size_255); 4268 ixl_stat_update48(hw, I40E_GLPRT_PTC511H(hw->port), 4269 I40E_GLPRT_PTC511L(hw->port), 4270 pf->stat_offsets_loaded, 4271 &osd->tx_size_511, &nsd->tx_size_511); 4272 ixl_stat_update48(hw, I40E_GLPRT_PTC1023H(hw->port), 4273 I40E_GLPRT_PTC1023L(hw->port), 4274 pf->stat_offsets_loaded, 4275 &osd->tx_size_1023, &nsd->tx_size_1023); 4276 ixl_stat_update48(hw, I40E_GLPRT_PTC1522H(hw->port), 4277 I40E_GLPRT_PTC1522L(hw->port), 4278 pf->stat_offsets_loaded, 4279 &osd->tx_size_1522, &nsd->tx_size_1522); 4280 ixl_stat_update48(hw, I40E_GLPRT_PTC9522H(hw->port), 4281 I40E_GLPRT_PTC9522L(hw->port), 4282 pf->stat_offsets_loaded, 4283 &osd->tx_size_big, &nsd->tx_size_big); 4284 4285 ixl_stat_update32(hw, I40E_GLPRT_RUC(hw->port), 4286 pf->stat_offsets_loaded, 4287 &osd->rx_undersize, &nsd->rx_undersize); 4288 ixl_stat_update32(hw, I40E_GLPRT_RFC(hw->port), 4289 pf->stat_offsets_loaded, 4290 &osd->rx_fragments, &nsd->rx_fragments); 4291 ixl_stat_update32(hw, I40E_GLPRT_ROC(hw->port), 4292 pf->stat_offsets_loaded, 4293 &osd->rx_oversize, &nsd->rx_oversize); 4294 ixl_stat_update32(hw, I40E_GLPRT_RJC(hw->port), 4295 pf->stat_offsets_loaded, 4296 &osd->rx_jabber, &nsd->rx_jabber); 4297 pf->stat_offsets_loaded = true; 4298 /* End hw stats */ 4299 4300 /* Update vsi stats */ 4301 ixl_update_vsi_stats(vsi); 4302 4303 for (int i = 0; i < pf->num_vfs; i++) { 4304 vf = &pf->vfs[i]; 4305 if (vf->vf_flags & VF_FLAG_ENABLED) 4306 ixl_update_eth_stats(&pf->vfs[i].vsi); 4307 } 4308 } 4309 4310 /* 4311 ** Tasklet handler for MSIX Adminq interrupts 4312 ** - do outside interrupt since it might sleep 4313 */ 4314 static void 4315 ixl_do_adminq(void *context, int pending) 4316 { 4317 struct ixl_pf *pf = context; 4318 struct i40e_hw *hw = &pf->hw; 4319 struct ixl_vsi *vsi = &pf->vsi; 4320 struct i40e_arq_event_info event; 4321 i40e_status ret; 4322 u32 reg, loop = 0; 4323 u16 opcode, result; 4324 4325 event.buf_len = IXL_AQ_BUF_SZ; 4326 event.msg_buf = malloc(event.buf_len, 4327 M_DEVBUF, M_NOWAIT | M_ZERO); 4328 if (!event.msg_buf) { 4329 printf("Unable to allocate adminq memory\n"); 4330 return; 4331 } 4332 4333 IXL_PF_LOCK(pf); 4334 /* clean and process any events */ 4335 do { 4336 ret = i40e_clean_arq_element(hw, &event, &result); 4337 if (ret) 4338 break; 4339 opcode = LE16_TO_CPU(event.desc.opcode); 4340 switch (opcode) { 4341 case i40e_aqc_opc_get_link_status: 4342 ixl_link_event(pf, &event); 4343 ixl_update_link_status(pf); 4344 break; 4345 case i40e_aqc_opc_send_msg_to_pf: 4346 #ifdef PCI_IOV 4347 ixl_handle_vf_msg(pf, &event); 4348 #endif 4349 break; 4350 case i40e_aqc_opc_event_lan_overflow: 4351 break; 4352 default: 4353 #ifdef IXL_DEBUG 4354 printf("AdminQ unknown event %x\n", opcode); 4355 #endif 4356 break; 4357 } 4358 4359 } while (result && (loop++ < IXL_ADM_LIMIT)); 4360 4361 reg = rd32(hw, I40E_PFINT_ICR0_ENA); 4362 reg |= I40E_PFINT_ICR0_ENA_ADMINQ_MASK; 4363 wr32(hw, I40E_PFINT_ICR0_ENA, reg); 4364 free(event.msg_buf, M_DEVBUF); 4365 4366 /* 4367 * If there are still messages to process, reschedule ourselves. 4368 * Otherwise, re-enable our interrupt and go to sleep. 4369 */ 4370 if (result > 0) 4371 taskqueue_enqueue(pf->tq, &pf->adminq); 4372 else 4373 ixl_enable_intr(vsi); 4374 4375 IXL_PF_UNLOCK(pf); 4376 } 4377 4378 #ifdef IXL_DEBUG_SYSCTL 4379 static int 4380 ixl_debug_info(SYSCTL_HANDLER_ARGS) 4381 { 4382 struct ixl_pf *pf; 4383 int error, input = 0; 4384 4385 error = sysctl_handle_int(oidp, &input, 0, req); 4386 4387 if (error || !req->newptr) 4388 return (error); 4389 4390 if (input == 1) { 4391 pf = (struct ixl_pf *)arg1; 4392 ixl_print_debug_info(pf); 4393 } 4394 4395 return (error); 4396 } 4397 4398 static void 4399 ixl_print_debug_info(struct ixl_pf *pf) 4400 { 4401 struct i40e_hw *hw = &pf->hw; 4402 struct ixl_vsi *vsi = &pf->vsi; 4403 struct ixl_queue *que = vsi->queues; 4404 struct rx_ring *rxr = &que->rxr; 4405 struct tx_ring *txr = &que->txr; 4406 u32 reg; 4407 4408 4409 printf("Queue irqs = %jx\n", (uintmax_t)que->irqs); 4410 printf("AdminQ irqs = %jx\n", (uintmax_t)pf->admin_irq); 4411 printf("RX next check = %x\n", rxr->next_check); 4412 printf("RX not ready = %jx\n", (uintmax_t)rxr->not_done); 4413 printf("RX packets = %jx\n", (uintmax_t)rxr->rx_packets); 4414 printf("TX desc avail = %x\n", txr->avail); 4415 4416 reg = rd32(hw, I40E_GLV_GORCL(0xc)); 4417 printf("RX Bytes = %x\n", reg); 4418 reg = rd32(hw, I40E_GLPRT_GORCL(hw->port)); 4419 printf("Port RX Bytes = %x\n", reg); 4420 reg = rd32(hw, I40E_GLV_RDPC(0xc)); 4421 printf("RX discard = %x\n", reg); 4422 reg = rd32(hw, I40E_GLPRT_RDPC(hw->port)); 4423 printf("Port RX discard = %x\n", reg); 4424 4425 reg = rd32(hw, I40E_GLV_TEPC(0xc)); 4426 printf("TX errors = %x\n", reg); 4427 reg = rd32(hw, I40E_GLV_GOTCL(0xc)); 4428 printf("TX Bytes = %x\n", reg); 4429 4430 reg = rd32(hw, I40E_GLPRT_RUC(hw->port)); 4431 printf("RX undersize = %x\n", reg); 4432 reg = rd32(hw, I40E_GLPRT_RFC(hw->port)); 4433 printf("RX fragments = %x\n", reg); 4434 reg = rd32(hw, I40E_GLPRT_ROC(hw->port)); 4435 printf("RX oversize = %x\n", reg); 4436 reg = rd32(hw, I40E_GLPRT_RLEC(hw->port)); 4437 printf("RX length error = %x\n", reg); 4438 reg = rd32(hw, I40E_GLPRT_MRFC(hw->port)); 4439 printf("mac remote fault = %x\n", reg); 4440 reg = rd32(hw, I40E_GLPRT_MLFC(hw->port)); 4441 printf("mac local fault = %x\n", reg); 4442 } 4443 #endif 4444 4445 /** 4446 * Update VSI-specific ethernet statistics counters. 4447 **/ 4448 void ixl_update_eth_stats(struct ixl_vsi *vsi) 4449 { 4450 struct ixl_pf *pf = (struct ixl_pf *)vsi->back; 4451 struct i40e_hw *hw = &pf->hw; 4452 struct i40e_eth_stats *es; 4453 struct i40e_eth_stats *oes; 4454 struct i40e_hw_port_stats *nsd; 4455 u16 stat_idx = vsi->info.stat_counter_idx; 4456 4457 es = &vsi->eth_stats; 4458 oes = &vsi->eth_stats_offsets; 4459 nsd = &pf->stats; 4460 4461 /* Gather up the stats that the hw collects */ 4462 ixl_stat_update32(hw, I40E_GLV_TEPC(stat_idx), 4463 vsi->stat_offsets_loaded, 4464 &oes->tx_errors, &es->tx_errors); 4465 ixl_stat_update32(hw, I40E_GLV_RDPC(stat_idx), 4466 vsi->stat_offsets_loaded, 4467 &oes->rx_discards, &es->rx_discards); 4468 4469 ixl_stat_update48(hw, I40E_GLV_GORCH(stat_idx), 4470 I40E_GLV_GORCL(stat_idx), 4471 vsi->stat_offsets_loaded, 4472 &oes->rx_bytes, &es->rx_bytes); 4473 ixl_stat_update48(hw, I40E_GLV_UPRCH(stat_idx), 4474 I40E_GLV_UPRCL(stat_idx), 4475 vsi->stat_offsets_loaded, 4476 &oes->rx_unicast, &es->rx_unicast); 4477 ixl_stat_update48(hw, I40E_GLV_MPRCH(stat_idx), 4478 I40E_GLV_MPRCL(stat_idx), 4479 vsi->stat_offsets_loaded, 4480 &oes->rx_multicast, &es->rx_multicast); 4481 ixl_stat_update48(hw, I40E_GLV_BPRCH(stat_idx), 4482 I40E_GLV_BPRCL(stat_idx), 4483 vsi->stat_offsets_loaded, 4484 &oes->rx_broadcast, &es->rx_broadcast); 4485 4486 ixl_stat_update48(hw, I40E_GLV_GOTCH(stat_idx), 4487 I40E_GLV_GOTCL(stat_idx), 4488 vsi->stat_offsets_loaded, 4489 &oes->tx_bytes, &es->tx_bytes); 4490 ixl_stat_update48(hw, I40E_GLV_UPTCH(stat_idx), 4491 I40E_GLV_UPTCL(stat_idx), 4492 vsi->stat_offsets_loaded, 4493 &oes->tx_unicast, &es->tx_unicast); 4494 ixl_stat_update48(hw, I40E_GLV_MPTCH(stat_idx), 4495 I40E_GLV_MPTCL(stat_idx), 4496 vsi->stat_offsets_loaded, 4497 &oes->tx_multicast, &es->tx_multicast); 4498 ixl_stat_update48(hw, I40E_GLV_BPTCH(stat_idx), 4499 I40E_GLV_BPTCL(stat_idx), 4500 vsi->stat_offsets_loaded, 4501 &oes->tx_broadcast, &es->tx_broadcast); 4502 vsi->stat_offsets_loaded = true; 4503 } 4504 4505 static void 4506 ixl_update_vsi_stats(struct ixl_vsi *vsi) 4507 { 4508 struct ixl_pf *pf; 4509 struct ifnet *ifp; 4510 struct i40e_eth_stats *es; 4511 u64 tx_discards; 4512 4513 struct i40e_hw_port_stats *nsd; 4514 4515 pf = vsi->back; 4516 ifp = vsi->ifp; 4517 es = &vsi->eth_stats; 4518 nsd = &pf->stats; 4519 4520 ixl_update_eth_stats(vsi); 4521 4522 tx_discards = es->tx_discards + nsd->tx_dropped_link_down; 4523 for (int i = 0; i < vsi->num_queues; i++) 4524 tx_discards += vsi->queues[i].txr.br->br_drops; 4525 4526 /* Update ifnet stats */ 4527 IXL_SET_IPACKETS(vsi, es->rx_unicast + 4528 es->rx_multicast + 4529 es->rx_broadcast); 4530 IXL_SET_OPACKETS(vsi, es->tx_unicast + 4531 es->tx_multicast + 4532 es->tx_broadcast); 4533 IXL_SET_IBYTES(vsi, es->rx_bytes); 4534 IXL_SET_OBYTES(vsi, es->tx_bytes); 4535 IXL_SET_IMCASTS(vsi, es->rx_multicast); 4536 IXL_SET_OMCASTS(vsi, es->tx_multicast); 4537 4538 IXL_SET_IERRORS(vsi, nsd->crc_errors + nsd->illegal_bytes + 4539 nsd->rx_undersize + nsd->rx_oversize + nsd->rx_fragments + 4540 nsd->rx_jabber); 4541 IXL_SET_OERRORS(vsi, es->tx_errors); 4542 IXL_SET_IQDROPS(vsi, es->rx_discards + nsd->eth.rx_discards); 4543 IXL_SET_OQDROPS(vsi, tx_discards); 4544 IXL_SET_NOPROTO(vsi, es->rx_unknown_protocol); 4545 IXL_SET_COLLISIONS(vsi, 0); 4546 } 4547 4548 /** 4549 * Reset all of the stats for the given pf 4550 **/ 4551 void ixl_pf_reset_stats(struct ixl_pf *pf) 4552 { 4553 bzero(&pf->stats, sizeof(struct i40e_hw_port_stats)); 4554 bzero(&pf->stats_offsets, sizeof(struct i40e_hw_port_stats)); 4555 pf->stat_offsets_loaded = false; 4556 } 4557 4558 /** 4559 * Resets all stats of the given vsi 4560 **/ 4561 void ixl_vsi_reset_stats(struct ixl_vsi *vsi) 4562 { 4563 bzero(&vsi->eth_stats, sizeof(struct i40e_eth_stats)); 4564 bzero(&vsi->eth_stats_offsets, sizeof(struct i40e_eth_stats)); 4565 vsi->stat_offsets_loaded = false; 4566 } 4567 4568 /** 4569 * Read and update a 48 bit stat from the hw 4570 * 4571 * Since the device stats are not reset at PFReset, they likely will not 4572 * be zeroed when the driver starts. We'll save the first values read 4573 * and use them as offsets to be subtracted from the raw values in order 4574 * to report stats that count from zero. 4575 **/ 4576 static void 4577 ixl_stat_update48(struct i40e_hw *hw, u32 hireg, u32 loreg, 4578 bool offset_loaded, u64 *offset, u64 *stat) 4579 { 4580 u64 new_data; 4581 4582 #if defined(__FreeBSD__) && (__FreeBSD_version >= 1000000) && defined(__amd64__) 4583 new_data = rd64(hw, loreg); 4584 #else 4585 /* 4586 * Use two rd32's instead of one rd64; FreeBSD versions before 4587 * 10 don't support 8 byte bus reads/writes. 4588 */ 4589 new_data = rd32(hw, loreg); 4590 new_data |= ((u64)(rd32(hw, hireg) & 0xFFFF)) << 32; 4591 #endif 4592 4593 if (!offset_loaded) 4594 *offset = new_data; 4595 if (new_data >= *offset) 4596 *stat = new_data - *offset; 4597 else 4598 *stat = (new_data + ((u64)1 << 48)) - *offset; 4599 *stat &= 0xFFFFFFFFFFFFULL; 4600 } 4601 4602 /** 4603 * Read and update a 32 bit stat from the hw 4604 **/ 4605 static void 4606 ixl_stat_update32(struct i40e_hw *hw, u32 reg, 4607 bool offset_loaded, u64 *offset, u64 *stat) 4608 { 4609 u32 new_data; 4610 4611 new_data = rd32(hw, reg); 4612 if (!offset_loaded) 4613 *offset = new_data; 4614 if (new_data >= *offset) 4615 *stat = (u32)(new_data - *offset); 4616 else 4617 *stat = (u32)((new_data + ((u64)1 << 32)) - *offset); 4618 } 4619 4620 /* 4621 ** Set flow control using sysctl: 4622 ** 0 - off 4623 ** 1 - rx pause 4624 ** 2 - tx pause 4625 ** 3 - full 4626 */ 4627 static int 4628 ixl_set_flowcntl(SYSCTL_HANDLER_ARGS) 4629 { 4630 /* 4631 * TODO: ensure flow control is disabled if 4632 * priority flow control is enabled 4633 * 4634 * TODO: ensure tx CRC by hardware should be enabled 4635 * if tx flow control is enabled. 4636 */ 4637 struct ixl_pf *pf = (struct ixl_pf *)arg1; 4638 struct i40e_hw *hw = &pf->hw; 4639 device_t dev = pf->dev; 4640 int error = 0; 4641 enum i40e_status_code aq_error = 0; 4642 u8 fc_aq_err = 0; 4643 4644 /* Get request */ 4645 error = sysctl_handle_int(oidp, &pf->fc, 0, req); 4646 if ((error) || (req->newptr == NULL)) 4647 return (error); 4648 if (pf->fc < 0 || pf->fc > 3) { 4649 device_printf(dev, 4650 "Invalid fc mode; valid modes are 0 through 3\n"); 4651 return (EINVAL); 4652 } 4653 4654 /* 4655 ** Changing flow control mode currently does not work on 4656 ** 40GBASE-CR4 PHYs 4657 */ 4658 if (hw->phy.link_info.phy_type == I40E_PHY_TYPE_40GBASE_CR4 4659 || hw->phy.link_info.phy_type == I40E_PHY_TYPE_40GBASE_CR4_CU) { 4660 device_printf(dev, "Changing flow control mode unsupported" 4661 " on 40GBase-CR4 media.\n"); 4662 return (ENODEV); 4663 } 4664 4665 /* Set fc ability for port */ 4666 hw->fc.requested_mode = pf->fc; 4667 aq_error = i40e_set_fc(hw, &fc_aq_err, TRUE); 4668 if (aq_error) { 4669 device_printf(dev, 4670 "%s: Error setting new fc mode %d; fc_err %#x\n", 4671 __func__, aq_error, fc_aq_err); 4672 return (EAGAIN); 4673 } 4674 4675 return (0); 4676 } 4677 4678 static int 4679 ixl_current_speed(SYSCTL_HANDLER_ARGS) 4680 { 4681 struct ixl_pf *pf = (struct ixl_pf *)arg1; 4682 struct i40e_hw *hw = &pf->hw; 4683 int error = 0, index = 0; 4684 4685 char *speeds[] = { 4686 "Unknown", 4687 "100M", 4688 "1G", 4689 "10G", 4690 "40G", 4691 "20G" 4692 }; 4693 4694 ixl_update_link_status(pf); 4695 4696 switch (hw->phy.link_info.link_speed) { 4697 case I40E_LINK_SPEED_100MB: 4698 index = 1; 4699 break; 4700 case I40E_LINK_SPEED_1GB: 4701 index = 2; 4702 break; 4703 case I40E_LINK_SPEED_10GB: 4704 index = 3; 4705 break; 4706 case I40E_LINK_SPEED_40GB: 4707 index = 4; 4708 break; 4709 case I40E_LINK_SPEED_20GB: 4710 index = 5; 4711 break; 4712 case I40E_LINK_SPEED_UNKNOWN: 4713 default: 4714 index = 0; 4715 break; 4716 } 4717 4718 error = sysctl_handle_string(oidp, speeds[index], 4719 strlen(speeds[index]), req); 4720 return (error); 4721 } 4722 4723 static int 4724 ixl_set_advertised_speeds(struct ixl_pf *pf, int speeds) 4725 { 4726 struct i40e_hw *hw = &pf->hw; 4727 device_t dev = pf->dev; 4728 struct i40e_aq_get_phy_abilities_resp abilities; 4729 struct i40e_aq_set_phy_config config; 4730 enum i40e_status_code aq_error = 0; 4731 4732 /* Get current capability information */ 4733 aq_error = i40e_aq_get_phy_capabilities(hw, 4734 FALSE, FALSE, &abilities, NULL); 4735 if (aq_error) { 4736 device_printf(dev, 4737 "%s: Error getting phy capabilities %d," 4738 " aq error: %d\n", __func__, aq_error, 4739 hw->aq.asq_last_status); 4740 return (EAGAIN); 4741 } 4742 4743 /* Prepare new config */ 4744 bzero(&config, sizeof(config)); 4745 config.phy_type = abilities.phy_type; 4746 config.abilities = abilities.abilities 4747 | I40E_AQ_PHY_ENABLE_ATOMIC_LINK; 4748 config.eee_capability = abilities.eee_capability; 4749 config.eeer = abilities.eeer_val; 4750 config.low_power_ctrl = abilities.d3_lpan; 4751 /* Translate into aq cmd link_speed */ 4752 if (speeds & 0x8) 4753 config.link_speed |= I40E_LINK_SPEED_20GB; 4754 if (speeds & 0x4) 4755 config.link_speed |= I40E_LINK_SPEED_10GB; 4756 if (speeds & 0x2) 4757 config.link_speed |= I40E_LINK_SPEED_1GB; 4758 if (speeds & 0x1) 4759 config.link_speed |= I40E_LINK_SPEED_100MB; 4760 4761 /* Do aq command & restart link */ 4762 aq_error = i40e_aq_set_phy_config(hw, &config, NULL); 4763 if (aq_error) { 4764 device_printf(dev, 4765 "%s: Error setting new phy config %d," 4766 " aq error: %d\n", __func__, aq_error, 4767 hw->aq.asq_last_status); 4768 return (EAGAIN); 4769 } 4770 4771 /* 4772 ** This seems a bit heavy handed, but we 4773 ** need to get a reinit on some devices 4774 */ 4775 IXL_PF_LOCK(pf); 4776 ixl_stop(pf); 4777 ixl_init_locked(pf); 4778 IXL_PF_UNLOCK(pf); 4779 4780 return (0); 4781 } 4782 4783 /* 4784 ** Control link advertise speed: 4785 ** Flags: 4786 ** 0x1 - advertise 100 Mb 4787 ** 0x2 - advertise 1G 4788 ** 0x4 - advertise 10G 4789 ** 0x8 - advertise 20G 4790 ** 4791 ** Does not work on 40G devices. 4792 */ 4793 static int 4794 ixl_set_advertise(SYSCTL_HANDLER_ARGS) 4795 { 4796 struct ixl_pf *pf = (struct ixl_pf *)arg1; 4797 struct i40e_hw *hw = &pf->hw; 4798 device_t dev = pf->dev; 4799 int requested_ls = 0; 4800 int error = 0; 4801 4802 /* 4803 ** FW doesn't support changing advertised speed 4804 ** for 40G devices; speed is always 40G. 4805 */ 4806 if (i40e_is_40G_device(hw->device_id)) 4807 return (ENODEV); 4808 4809 /* Read in new mode */ 4810 requested_ls = pf->advertised_speed; 4811 error = sysctl_handle_int(oidp, &requested_ls, 0, req); 4812 if ((error) || (req->newptr == NULL)) 4813 return (error); 4814 /* Check for sane value */ 4815 if (requested_ls < 0x1 || requested_ls > 0xE) { 4816 device_printf(dev, "Invalid advertised speed; " 4817 "valid modes are 0x1 through 0xE\n"); 4818 return (EINVAL); 4819 } 4820 /* Then check for validity based on adapter type */ 4821 switch (hw->device_id) { 4822 case I40E_DEV_ID_10G_BASE_T: 4823 if (requested_ls & 0x8) { 4824 device_printf(dev, 4825 "20Gbs speed not supported on this device.\n"); 4826 return (EINVAL); 4827 } 4828 break; 4829 case I40E_DEV_ID_20G_KR2: 4830 if (requested_ls & 0x1) { 4831 device_printf(dev, 4832 "100Mbs speed not supported on this device.\n"); 4833 return (EINVAL); 4834 } 4835 break; 4836 default: 4837 if (requested_ls & ~0x6) { 4838 device_printf(dev, 4839 "Only 1/10Gbs speeds are supported on this device.\n"); 4840 return (EINVAL); 4841 } 4842 break; 4843 } 4844 4845 /* Exit if no change */ 4846 if (pf->advertised_speed == requested_ls) 4847 return (0); 4848 4849 error = ixl_set_advertised_speeds(pf, requested_ls); 4850 if (error) 4851 return (error); 4852 4853 pf->advertised_speed = requested_ls; 4854 ixl_update_link_status(pf); 4855 return (0); 4856 } 4857 4858 /* 4859 ** Get the width and transaction speed of 4860 ** the bus this adapter is plugged into. 4861 */ 4862 static u16 4863 ixl_get_bus_info(struct i40e_hw *hw, device_t dev) 4864 { 4865 u16 link; 4866 u32 offset; 4867 4868 4869 /* Get the PCI Express Capabilities offset */ 4870 pci_find_cap(dev, PCIY_EXPRESS, &offset); 4871 4872 /* ...and read the Link Status Register */ 4873 link = pci_read_config(dev, offset + PCIER_LINK_STA, 2); 4874 4875 switch (link & I40E_PCI_LINK_WIDTH) { 4876 case I40E_PCI_LINK_WIDTH_1: 4877 hw->bus.width = i40e_bus_width_pcie_x1; 4878 break; 4879 case I40E_PCI_LINK_WIDTH_2: 4880 hw->bus.width = i40e_bus_width_pcie_x2; 4881 break; 4882 case I40E_PCI_LINK_WIDTH_4: 4883 hw->bus.width = i40e_bus_width_pcie_x4; 4884 break; 4885 case I40E_PCI_LINK_WIDTH_8: 4886 hw->bus.width = i40e_bus_width_pcie_x8; 4887 break; 4888 default: 4889 hw->bus.width = i40e_bus_width_unknown; 4890 break; 4891 } 4892 4893 switch (link & I40E_PCI_LINK_SPEED) { 4894 case I40E_PCI_LINK_SPEED_2500: 4895 hw->bus.speed = i40e_bus_speed_2500; 4896 break; 4897 case I40E_PCI_LINK_SPEED_5000: 4898 hw->bus.speed = i40e_bus_speed_5000; 4899 break; 4900 case I40E_PCI_LINK_SPEED_8000: 4901 hw->bus.speed = i40e_bus_speed_8000; 4902 break; 4903 default: 4904 hw->bus.speed = i40e_bus_speed_unknown; 4905 break; 4906 } 4907 4908 4909 device_printf(dev,"PCI Express Bus: Speed %s %s\n", 4910 ((hw->bus.speed == i40e_bus_speed_8000) ? "8.0GT/s": 4911 (hw->bus.speed == i40e_bus_speed_5000) ? "5.0GT/s": 4912 (hw->bus.speed == i40e_bus_speed_2500) ? "2.5GT/s":"Unknown"), 4913 (hw->bus.width == i40e_bus_width_pcie_x8) ? "Width x8" : 4914 (hw->bus.width == i40e_bus_width_pcie_x4) ? "Width x4" : 4915 (hw->bus.width == i40e_bus_width_pcie_x1) ? "Width x1" : 4916 ("Unknown")); 4917 4918 if ((hw->bus.width <= i40e_bus_width_pcie_x8) && 4919 (hw->bus.speed < i40e_bus_speed_8000)) { 4920 device_printf(dev, "PCI-Express bandwidth available" 4921 " for this device\n may be insufficient for" 4922 " optimal performance.\n"); 4923 device_printf(dev, "For expected performance a x8 " 4924 "PCIE Gen3 slot is required.\n"); 4925 } 4926 4927 return (link); 4928 } 4929 4930 static int 4931 ixl_sysctl_show_fw(SYSCTL_HANDLER_ARGS) 4932 { 4933 struct ixl_pf *pf = (struct ixl_pf *)arg1; 4934 struct i40e_hw *hw = &pf->hw; 4935 char buf[32]; 4936 4937 snprintf(buf, sizeof(buf), 4938 "f%d.%d a%d.%d n%02x.%02x e%08x", 4939 hw->aq.fw_maj_ver, hw->aq.fw_min_ver, 4940 hw->aq.api_maj_ver, hw->aq.api_min_ver, 4941 (hw->nvm.version & IXL_NVM_VERSION_HI_MASK) >> 4942 IXL_NVM_VERSION_HI_SHIFT, 4943 (hw->nvm.version & IXL_NVM_VERSION_LO_MASK) >> 4944 IXL_NVM_VERSION_LO_SHIFT, 4945 hw->nvm.eetrack); 4946 return (sysctl_handle_string(oidp, buf, strlen(buf), req)); 4947 } 4948 4949 4950 #ifdef IXL_DEBUG_SYSCTL 4951 static int 4952 ixl_sysctl_link_status(SYSCTL_HANDLER_ARGS) 4953 { 4954 struct ixl_pf *pf = (struct ixl_pf *)arg1; 4955 struct i40e_hw *hw = &pf->hw; 4956 struct i40e_link_status link_status; 4957 char buf[512]; 4958 4959 enum i40e_status_code aq_error = 0; 4960 4961 aq_error = i40e_aq_get_link_info(hw, TRUE, &link_status, NULL); 4962 if (aq_error) { 4963 printf("i40e_aq_get_link_info() error %d\n", aq_error); 4964 return (EPERM); 4965 } 4966 4967 sprintf(buf, "\n" 4968 "PHY Type : %#04x\n" 4969 "Speed : %#04x\n" 4970 "Link info: %#04x\n" 4971 "AN info : %#04x\n" 4972 "Ext info : %#04x", 4973 link_status.phy_type, link_status.link_speed, 4974 link_status.link_info, link_status.an_info, 4975 link_status.ext_info); 4976 4977 return (sysctl_handle_string(oidp, buf, strlen(buf), req)); 4978 } 4979 4980 static int 4981 ixl_sysctl_phy_abilities(SYSCTL_HANDLER_ARGS) 4982 { 4983 struct ixl_pf *pf = (struct ixl_pf *)arg1; 4984 struct i40e_hw *hw = &pf->hw; 4985 char buf[512]; 4986 enum i40e_status_code aq_error = 0; 4987 4988 struct i40e_aq_get_phy_abilities_resp abilities; 4989 4990 aq_error = i40e_aq_get_phy_capabilities(hw, 4991 TRUE, FALSE, &abilities, NULL); 4992 if (aq_error) { 4993 printf("i40e_aq_get_phy_capabilities() error %d\n", aq_error); 4994 return (EPERM); 4995 } 4996 4997 sprintf(buf, "\n" 4998 "PHY Type : %#010x\n" 4999 "Speed : %#04x\n" 5000 "Abilities: %#04x\n" 5001 "EEE cap : %#06x\n" 5002 "EEER reg : %#010x\n" 5003 "D3 Lpan : %#04x", 5004 abilities.phy_type, abilities.link_speed, 5005 abilities.abilities, abilities.eee_capability, 5006 abilities.eeer_val, abilities.d3_lpan); 5007 5008 return (sysctl_handle_string(oidp, buf, strlen(buf), req)); 5009 } 5010 5011 static int 5012 ixl_sysctl_sw_filter_list(SYSCTL_HANDLER_ARGS) 5013 { 5014 struct ixl_pf *pf = (struct ixl_pf *)arg1; 5015 struct ixl_vsi *vsi = &pf->vsi; 5016 struct ixl_mac_filter *f; 5017 char *buf, *buf_i; 5018 5019 int error = 0; 5020 int ftl_len = 0; 5021 int ftl_counter = 0; 5022 int buf_len = 0; 5023 int entry_len = 42; 5024 5025 SLIST_FOREACH(f, &vsi->ftl, next) { 5026 ftl_len++; 5027 } 5028 5029 if (ftl_len < 1) { 5030 sysctl_handle_string(oidp, "(none)", 6, req); 5031 return (0); 5032 } 5033 5034 buf_len = sizeof(char) * (entry_len + 1) * ftl_len + 2; 5035 buf = buf_i = malloc(buf_len, M_DEVBUF, M_NOWAIT); 5036 5037 sprintf(buf_i++, "\n"); 5038 SLIST_FOREACH(f, &vsi->ftl, next) { 5039 sprintf(buf_i, 5040 MAC_FORMAT ", vlan %4d, flags %#06x", 5041 MAC_FORMAT_ARGS(f->macaddr), f->vlan, f->flags); 5042 buf_i += entry_len; 5043 /* don't print '\n' for last entry */ 5044 if (++ftl_counter != ftl_len) { 5045 sprintf(buf_i, "\n"); 5046 buf_i++; 5047 } 5048 } 5049 5050 error = sysctl_handle_string(oidp, buf, strlen(buf), req); 5051 if (error) 5052 printf("sysctl error: %d\n", error); 5053 free(buf, M_DEVBUF); 5054 return error; 5055 } 5056 5057 #define IXL_SW_RES_SIZE 0x14 5058 static int 5059 ixl_res_alloc_cmp(const void *a, const void *b) 5060 { 5061 const struct i40e_aqc_switch_resource_alloc_element_resp *one, *two; 5062 one = (const struct i40e_aqc_switch_resource_alloc_element_resp *)a; 5063 two = (const struct i40e_aqc_switch_resource_alloc_element_resp *)b; 5064 5065 return ((int)one->resource_type - (int)two->resource_type); 5066 } 5067 5068 static int 5069 ixl_sysctl_hw_res_alloc(SYSCTL_HANDLER_ARGS) 5070 { 5071 struct ixl_pf *pf = (struct ixl_pf *)arg1; 5072 struct i40e_hw *hw = &pf->hw; 5073 device_t dev = pf->dev; 5074 struct sbuf *buf; 5075 int error = 0; 5076 5077 u8 num_entries; 5078 struct i40e_aqc_switch_resource_alloc_element_resp resp[IXL_SW_RES_SIZE]; 5079 5080 buf = sbuf_new_for_sysctl(NULL, NULL, 0, req); 5081 if (!buf) { 5082 device_printf(dev, "Could not allocate sbuf for output.\n"); 5083 return (ENOMEM); 5084 } 5085 5086 bzero(resp, sizeof(resp)); 5087 error = i40e_aq_get_switch_resource_alloc(hw, &num_entries, 5088 resp, 5089 IXL_SW_RES_SIZE, 5090 NULL); 5091 if (error) { 5092 device_printf(dev, 5093 "%s: get_switch_resource_alloc() error %d, aq error %d\n", 5094 __func__, error, hw->aq.asq_last_status); 5095 sbuf_delete(buf); 5096 return error; 5097 } 5098 5099 /* Sort entries by type for display */ 5100 qsort(resp, num_entries, 5101 sizeof(struct i40e_aqc_switch_resource_alloc_element_resp), 5102 &ixl_res_alloc_cmp); 5103 5104 sbuf_cat(buf, "\n"); 5105 sbuf_printf(buf, "# of entries: %d\n", num_entries); 5106 sbuf_printf(buf, 5107 "Type | Guaranteed | Total | Used | Un-allocated\n" 5108 " | (this) | (all) | (this) | (all) \n"); 5109 for (int i = 0; i < num_entries; i++) { 5110 sbuf_printf(buf, 5111 "%#4x | %10d %5d %6d %12d", 5112 resp[i].resource_type, 5113 resp[i].guaranteed, 5114 resp[i].total, 5115 resp[i].used, 5116 resp[i].total_unalloced); 5117 if (i < num_entries - 1) 5118 sbuf_cat(buf, "\n"); 5119 } 5120 5121 error = sbuf_finish(buf); 5122 if (error) { 5123 device_printf(dev, "Error finishing sbuf: %d\n", error); 5124 sbuf_delete(buf); 5125 return error; 5126 } 5127 5128 error = sysctl_handle_string(oidp, sbuf_data(buf), sbuf_len(buf), req); 5129 if (error) 5130 device_printf(dev, "sysctl error: %d\n", error); 5131 sbuf_delete(buf); 5132 return error; 5133 } 5134 5135 /* 5136 ** Caller must init and delete sbuf; this function will clear and 5137 ** finish it for caller. 5138 */ 5139 static char * 5140 ixl_switch_element_string(struct sbuf *s, u16 seid, bool uplink) 5141 { 5142 sbuf_clear(s); 5143 5144 if (seid == 0 && uplink) 5145 sbuf_cat(s, "Network"); 5146 else if (seid == 0) 5147 sbuf_cat(s, "Host"); 5148 else if (seid == 1) 5149 sbuf_cat(s, "EMP"); 5150 else if (seid <= 5) 5151 sbuf_printf(s, "MAC %d", seid - 2); 5152 else if (seid <= 15) 5153 sbuf_cat(s, "Reserved"); 5154 else if (seid <= 31) 5155 sbuf_printf(s, "PF %d", seid - 16); 5156 else if (seid <= 159) 5157 sbuf_printf(s, "VF %d", seid - 32); 5158 else if (seid <= 287) 5159 sbuf_cat(s, "Reserved"); 5160 else if (seid <= 511) 5161 sbuf_cat(s, "Other"); // for other structures 5162 else if (seid <= 895) 5163 sbuf_printf(s, "VSI %d", seid - 512); 5164 else if (seid <= 1023) 5165 sbuf_printf(s, "Reserved"); 5166 else 5167 sbuf_cat(s, "Invalid"); 5168 5169 sbuf_finish(s); 5170 return sbuf_data(s); 5171 } 5172 5173 static int 5174 ixl_sysctl_switch_config(SYSCTL_HANDLER_ARGS) 5175 { 5176 struct ixl_pf *pf = (struct ixl_pf *)arg1; 5177 struct i40e_hw *hw = &pf->hw; 5178 device_t dev = pf->dev; 5179 struct sbuf *buf; 5180 struct sbuf *nmbuf; 5181 int error = 0; 5182 u8 aq_buf[I40E_AQ_LARGE_BUF]; 5183 5184 u16 next = 0; 5185 struct i40e_aqc_get_switch_config_resp *sw_config; 5186 sw_config = (struct i40e_aqc_get_switch_config_resp *)aq_buf; 5187 5188 buf = sbuf_new_for_sysctl(NULL, NULL, 0, req); 5189 if (!buf) { 5190 device_printf(dev, "Could not allocate sbuf for sysctl output.\n"); 5191 return (ENOMEM); 5192 } 5193 5194 error = i40e_aq_get_switch_config(hw, sw_config, 5195 sizeof(aq_buf), &next, NULL); 5196 if (error) { 5197 device_printf(dev, 5198 "%s: aq_get_switch_config() error %d, aq error %d\n", 5199 __func__, error, hw->aq.asq_last_status); 5200 sbuf_delete(buf); 5201 return error; 5202 } 5203 5204 nmbuf = sbuf_new_auto(); 5205 if (!nmbuf) { 5206 device_printf(dev, "Could not allocate sbuf for name output.\n"); 5207 return (ENOMEM); 5208 } 5209 5210 sbuf_cat(buf, "\n"); 5211 // Assuming <= 255 elements in switch 5212 sbuf_printf(buf, "# of elements: %d\n", sw_config->header.num_reported); 5213 /* Exclude: 5214 ** Revision -- all elements are revision 1 for now 5215 */ 5216 sbuf_printf(buf, 5217 "SEID ( Name ) | Uplink | Downlink | Conn Type\n" 5218 " | | | (uplink)\n"); 5219 for (int i = 0; i < sw_config->header.num_reported; i++) { 5220 // "%4d (%8s) | %8s %8s %#8x", 5221 sbuf_printf(buf, "%4d", sw_config->element[i].seid); 5222 sbuf_cat(buf, " "); 5223 sbuf_printf(buf, "(%8s)", ixl_switch_element_string(nmbuf, 5224 sw_config->element[i].seid, false)); 5225 sbuf_cat(buf, " | "); 5226 sbuf_printf(buf, "%8s", ixl_switch_element_string(nmbuf, 5227 sw_config->element[i].uplink_seid, true)); 5228 sbuf_cat(buf, " "); 5229 sbuf_printf(buf, "%8s", ixl_switch_element_string(nmbuf, 5230 sw_config->element[i].downlink_seid, false)); 5231 sbuf_cat(buf, " "); 5232 sbuf_printf(buf, "%#8x", sw_config->element[i].connection_type); 5233 if (i < sw_config->header.num_reported - 1) 5234 sbuf_cat(buf, "\n"); 5235 } 5236 sbuf_delete(nmbuf); 5237 5238 error = sbuf_finish(buf); 5239 if (error) { 5240 device_printf(dev, "Error finishing sbuf: %d\n", error); 5241 sbuf_delete(buf); 5242 return error; 5243 } 5244 5245 error = sysctl_handle_string(oidp, sbuf_data(buf), sbuf_len(buf), req); 5246 if (error) 5247 device_printf(dev, "sysctl error: %d\n", error); 5248 sbuf_delete(buf); 5249 5250 return (error); 5251 } 5252 #endif /* IXL_DEBUG_SYSCTL */ 5253 5254 5255 #ifdef PCI_IOV 5256 static int 5257 ixl_vf_alloc_vsi(struct ixl_pf *pf, struct ixl_vf *vf) 5258 { 5259 struct i40e_hw *hw; 5260 struct ixl_vsi *vsi; 5261 struct i40e_vsi_context vsi_ctx; 5262 int i; 5263 uint16_t first_queue; 5264 enum i40e_status_code code; 5265 5266 hw = &pf->hw; 5267 vsi = &pf->vsi; 5268 5269 vsi_ctx.pf_num = hw->pf_id; 5270 vsi_ctx.uplink_seid = pf->veb_seid; 5271 vsi_ctx.connection_type = IXL_VSI_DATA_PORT; 5272 vsi_ctx.vf_num = hw->func_caps.vf_base_id + vf->vf_num; 5273 vsi_ctx.flags = I40E_AQ_VSI_TYPE_VF; 5274 5275 bzero(&vsi_ctx.info, sizeof(vsi_ctx.info)); 5276 5277 vsi_ctx.info.valid_sections = htole16(I40E_AQ_VSI_PROP_SWITCH_VALID); 5278 vsi_ctx.info.switch_id = htole16(0); 5279 5280 vsi_ctx.info.valid_sections |= htole16(I40E_AQ_VSI_PROP_SECURITY_VALID); 5281 vsi_ctx.info.sec_flags = 0; 5282 if (vf->vf_flags & VF_FLAG_MAC_ANTI_SPOOF) 5283 vsi_ctx.info.sec_flags |= I40E_AQ_VSI_SEC_FLAG_ENABLE_MAC_CHK; 5284 5285 vsi_ctx.info.valid_sections |= htole16(I40E_AQ_VSI_PROP_VLAN_VALID); 5286 vsi_ctx.info.port_vlan_flags = I40E_AQ_VSI_PVLAN_MODE_ALL | 5287 I40E_AQ_VSI_PVLAN_EMOD_NOTHING; 5288 5289 vsi_ctx.info.valid_sections |= 5290 htole16(I40E_AQ_VSI_PROP_QUEUE_MAP_VALID); 5291 vsi_ctx.info.mapping_flags = htole16(I40E_AQ_VSI_QUE_MAP_NONCONTIG); 5292 first_queue = vsi->num_queues + vf->vf_num * IXLV_MAX_QUEUES; 5293 for (i = 0; i < IXLV_MAX_QUEUES; i++) 5294 vsi_ctx.info.queue_mapping[i] = htole16(first_queue + i); 5295 for (; i < nitems(vsi_ctx.info.queue_mapping); i++) 5296 vsi_ctx.info.queue_mapping[i] = htole16(I40E_AQ_VSI_QUEUE_MASK); 5297 5298 vsi_ctx.info.tc_mapping[0] = htole16( 5299 (0 << I40E_AQ_VSI_TC_QUE_OFFSET_SHIFT) | 5300 (1 << I40E_AQ_VSI_TC_QUE_NUMBER_SHIFT)); 5301 5302 code = i40e_aq_add_vsi(hw, &vsi_ctx, NULL); 5303 if (code != I40E_SUCCESS) 5304 return (ixl_adminq_err_to_errno(hw->aq.asq_last_status)); 5305 vf->vsi.seid = vsi_ctx.seid; 5306 vf->vsi.vsi_num = vsi_ctx.vsi_number; 5307 vf->vsi.first_queue = first_queue; 5308 vf->vsi.num_queues = IXLV_MAX_QUEUES; 5309 5310 code = i40e_aq_get_vsi_params(hw, &vsi_ctx, NULL); 5311 if (code != I40E_SUCCESS) 5312 return (ixl_adminq_err_to_errno(hw->aq.asq_last_status)); 5313 5314 code = i40e_aq_config_vsi_bw_limit(hw, vf->vsi.seid, 0, 0, NULL); 5315 if (code != I40E_SUCCESS) { 5316 device_printf(pf->dev, "Failed to disable BW limit: %d\n", 5317 ixl_adminq_err_to_errno(hw->aq.asq_last_status)); 5318 return (ixl_adminq_err_to_errno(hw->aq.asq_last_status)); 5319 } 5320 5321 memcpy(&vf->vsi.info, &vsi_ctx.info, sizeof(vf->vsi.info)); 5322 return (0); 5323 } 5324 5325 static int 5326 ixl_vf_setup_vsi(struct ixl_pf *pf, struct ixl_vf *vf) 5327 { 5328 struct i40e_hw *hw; 5329 int error; 5330 5331 hw = &pf->hw; 5332 5333 error = ixl_vf_alloc_vsi(pf, vf); 5334 if (error != 0) 5335 return (error); 5336 5337 vf->vsi.hw_filters_add = 0; 5338 vf->vsi.hw_filters_del = 0; 5339 ixl_add_filter(&vf->vsi, ixl_bcast_addr, IXL_VLAN_ANY); 5340 ixl_reconfigure_filters(&vf->vsi); 5341 5342 return (0); 5343 } 5344 5345 static void 5346 ixl_vf_map_vsi_queue(struct i40e_hw *hw, struct ixl_vf *vf, int qnum, 5347 uint32_t val) 5348 { 5349 uint32_t qtable; 5350 int index, shift; 5351 5352 /* 5353 * Two queues are mapped in a single register, so we have to do some 5354 * gymnastics to convert the queue number into a register index and 5355 * shift. 5356 */ 5357 index = qnum / 2; 5358 shift = (qnum % 2) * I40E_VSILAN_QTABLE_QINDEX_1_SHIFT; 5359 5360 qtable = rd32(hw, I40E_VSILAN_QTABLE(index, vf->vsi.vsi_num)); 5361 qtable &= ~(I40E_VSILAN_QTABLE_QINDEX_0_MASK << shift); 5362 qtable |= val << shift; 5363 wr32(hw, I40E_VSILAN_QTABLE(index, vf->vsi.vsi_num), qtable); 5364 } 5365 5366 static void 5367 ixl_vf_map_queues(struct ixl_pf *pf, struct ixl_vf *vf) 5368 { 5369 struct i40e_hw *hw; 5370 uint32_t qtable; 5371 int i; 5372 5373 hw = &pf->hw; 5374 5375 /* 5376 * Contiguous mappings aren't actually supported by the hardware, 5377 * so we have to use non-contiguous mappings. 5378 */ 5379 wr32(hw, I40E_VSILAN_QBASE(vf->vsi.vsi_num), 5380 I40E_VSILAN_QBASE_VSIQTABLE_ENA_MASK); 5381 5382 wr32(hw, I40E_VPLAN_MAPENA(vf->vf_num), 5383 I40E_VPLAN_MAPENA_TXRX_ENA_MASK); 5384 5385 for (i = 0; i < vf->vsi.num_queues; i++) { 5386 qtable = (vf->vsi.first_queue + i) << 5387 I40E_VPLAN_QTABLE_QINDEX_SHIFT; 5388 5389 wr32(hw, I40E_VPLAN_QTABLE(i, vf->vf_num), qtable); 5390 } 5391 5392 /* Map queues allocated to VF to its VSI. */ 5393 for (i = 0; i < vf->vsi.num_queues; i++) 5394 ixl_vf_map_vsi_queue(hw, vf, i, vf->vsi.first_queue + i); 5395 5396 /* Set rest of VSI queues as unused. */ 5397 for (; i < IXL_MAX_VSI_QUEUES; i++) 5398 ixl_vf_map_vsi_queue(hw, vf, i, 5399 I40E_VSILAN_QTABLE_QINDEX_0_MASK); 5400 5401 ixl_flush(hw); 5402 } 5403 5404 static void 5405 ixl_vf_vsi_release(struct ixl_pf *pf, struct ixl_vsi *vsi) 5406 { 5407 struct i40e_hw *hw; 5408 5409 hw = &pf->hw; 5410 5411 if (vsi->seid == 0) 5412 return; 5413 5414 i40e_aq_delete_element(hw, vsi->seid, NULL); 5415 } 5416 5417 static void 5418 ixl_vf_disable_queue_intr(struct i40e_hw *hw, uint32_t vfint_reg) 5419 { 5420 5421 wr32(hw, vfint_reg, I40E_VFINT_DYN_CTLN_CLEARPBA_MASK); 5422 ixl_flush(hw); 5423 } 5424 5425 static void 5426 ixl_vf_unregister_intr(struct i40e_hw *hw, uint32_t vpint_reg) 5427 { 5428 5429 wr32(hw, vpint_reg, I40E_VPINT_LNKLSTN_FIRSTQ_TYPE_MASK | 5430 I40E_VPINT_LNKLSTN_FIRSTQ_INDX_MASK); 5431 ixl_flush(hw); 5432 } 5433 5434 static void 5435 ixl_vf_release_resources(struct ixl_pf *pf, struct ixl_vf *vf) 5436 { 5437 struct i40e_hw *hw; 5438 uint32_t vfint_reg, vpint_reg; 5439 int i; 5440 5441 hw = &pf->hw; 5442 5443 ixl_vf_vsi_release(pf, &vf->vsi); 5444 5445 /* Index 0 has a special register. */ 5446 ixl_vf_disable_queue_intr(hw, I40E_VFINT_DYN_CTL0(vf->vf_num)); 5447 5448 for (i = 1; i < hw->func_caps.num_msix_vectors_vf; i++) { 5449 vfint_reg = IXL_VFINT_DYN_CTLN_REG(hw, i , vf->vf_num); 5450 ixl_vf_disable_queue_intr(hw, vfint_reg); 5451 } 5452 5453 /* Index 0 has a special register. */ 5454 ixl_vf_unregister_intr(hw, I40E_VPINT_LNKLST0(vf->vf_num)); 5455 5456 for (i = 1; i < hw->func_caps.num_msix_vectors_vf; i++) { 5457 vpint_reg = IXL_VPINT_LNKLSTN_REG(hw, i, vf->vf_num); 5458 ixl_vf_unregister_intr(hw, vpint_reg); 5459 } 5460 5461 vf->vsi.num_queues = 0; 5462 } 5463 5464 static int 5465 ixl_flush_pcie(struct ixl_pf *pf, struct ixl_vf *vf) 5466 { 5467 struct i40e_hw *hw; 5468 int i; 5469 uint16_t global_vf_num; 5470 uint32_t ciad; 5471 5472 hw = &pf->hw; 5473 global_vf_num = hw->func_caps.vf_base_id + vf->vf_num; 5474 5475 wr32(hw, I40E_PF_PCI_CIAA, IXL_PF_PCI_CIAA_VF_DEVICE_STATUS | 5476 (global_vf_num << I40E_PF_PCI_CIAA_VF_NUM_SHIFT)); 5477 for (i = 0; i < IXL_VF_RESET_TIMEOUT; i++) { 5478 ciad = rd32(hw, I40E_PF_PCI_CIAD); 5479 if ((ciad & IXL_PF_PCI_CIAD_VF_TRANS_PENDING_MASK) == 0) 5480 return (0); 5481 DELAY(1); 5482 } 5483 5484 return (ETIMEDOUT); 5485 } 5486 5487 static void 5488 ixl_reset_vf(struct ixl_pf *pf, struct ixl_vf *vf) 5489 { 5490 struct i40e_hw *hw; 5491 uint32_t vfrtrig; 5492 5493 hw = &pf->hw; 5494 5495 vfrtrig = rd32(hw, I40E_VPGEN_VFRTRIG(vf->vf_num)); 5496 vfrtrig |= I40E_VPGEN_VFRTRIG_VFSWR_MASK; 5497 wr32(hw, I40E_VPGEN_VFRTRIG(vf->vf_num), vfrtrig); 5498 ixl_flush(hw); 5499 5500 ixl_reinit_vf(pf, vf); 5501 } 5502 5503 static void 5504 ixl_reinit_vf(struct ixl_pf *pf, struct ixl_vf *vf) 5505 { 5506 struct i40e_hw *hw; 5507 uint32_t vfrstat, vfrtrig; 5508 int i, error; 5509 5510 hw = &pf->hw; 5511 5512 error = ixl_flush_pcie(pf, vf); 5513 if (error != 0) 5514 device_printf(pf->dev, 5515 "Timed out waiting for PCIe activity to stop on VF-%d\n", 5516 vf->vf_num); 5517 5518 for (i = 0; i < IXL_VF_RESET_TIMEOUT; i++) { 5519 DELAY(10); 5520 5521 vfrstat = rd32(hw, I40E_VPGEN_VFRSTAT(vf->vf_num)); 5522 if (vfrstat & I40E_VPGEN_VFRSTAT_VFRD_MASK) 5523 break; 5524 } 5525 5526 if (i == IXL_VF_RESET_TIMEOUT) 5527 device_printf(pf->dev, "VF %d failed to reset\n", vf->vf_num); 5528 5529 wr32(hw, I40E_VFGEN_RSTAT1(vf->vf_num), I40E_VFR_COMPLETED); 5530 5531 vfrtrig = rd32(hw, I40E_VPGEN_VFRTRIG(vf->vf_num)); 5532 vfrtrig &= ~I40E_VPGEN_VFRTRIG_VFSWR_MASK; 5533 wr32(hw, I40E_VPGEN_VFRTRIG(vf->vf_num), vfrtrig); 5534 5535 if (vf->vsi.seid != 0) 5536 ixl_disable_rings(&vf->vsi); 5537 5538 ixl_vf_release_resources(pf, vf); 5539 ixl_vf_setup_vsi(pf, vf); 5540 ixl_vf_map_queues(pf, vf); 5541 5542 wr32(hw, I40E_VFGEN_RSTAT1(vf->vf_num), I40E_VFR_VFACTIVE); 5543 ixl_flush(hw); 5544 } 5545 5546 static const char * 5547 ixl_vc_opcode_str(uint16_t op) 5548 { 5549 5550 switch (op) { 5551 case I40E_VIRTCHNL_OP_VERSION: 5552 return ("VERSION"); 5553 case I40E_VIRTCHNL_OP_RESET_VF: 5554 return ("RESET_VF"); 5555 case I40E_VIRTCHNL_OP_GET_VF_RESOURCES: 5556 return ("GET_VF_RESOURCES"); 5557 case I40E_VIRTCHNL_OP_CONFIG_TX_QUEUE: 5558 return ("CONFIG_TX_QUEUE"); 5559 case I40E_VIRTCHNL_OP_CONFIG_RX_QUEUE: 5560 return ("CONFIG_RX_QUEUE"); 5561 case I40E_VIRTCHNL_OP_CONFIG_VSI_QUEUES: 5562 return ("CONFIG_VSI_QUEUES"); 5563 case I40E_VIRTCHNL_OP_CONFIG_IRQ_MAP: 5564 return ("CONFIG_IRQ_MAP"); 5565 case I40E_VIRTCHNL_OP_ENABLE_QUEUES: 5566 return ("ENABLE_QUEUES"); 5567 case I40E_VIRTCHNL_OP_DISABLE_QUEUES: 5568 return ("DISABLE_QUEUES"); 5569 case I40E_VIRTCHNL_OP_ADD_ETHER_ADDRESS: 5570 return ("ADD_ETHER_ADDRESS"); 5571 case I40E_VIRTCHNL_OP_DEL_ETHER_ADDRESS: 5572 return ("DEL_ETHER_ADDRESS"); 5573 case I40E_VIRTCHNL_OP_ADD_VLAN: 5574 return ("ADD_VLAN"); 5575 case I40E_VIRTCHNL_OP_DEL_VLAN: 5576 return ("DEL_VLAN"); 5577 case I40E_VIRTCHNL_OP_CONFIG_PROMISCUOUS_MODE: 5578 return ("CONFIG_PROMISCUOUS_MODE"); 5579 case I40E_VIRTCHNL_OP_GET_STATS: 5580 return ("GET_STATS"); 5581 case I40E_VIRTCHNL_OP_FCOE: 5582 return ("FCOE"); 5583 case I40E_VIRTCHNL_OP_EVENT: 5584 return ("EVENT"); 5585 default: 5586 return ("UNKNOWN"); 5587 } 5588 } 5589 5590 static int 5591 ixl_vc_opcode_level(uint16_t opcode) 5592 { 5593 5594 switch (opcode) { 5595 case I40E_VIRTCHNL_OP_GET_STATS: 5596 return (10); 5597 default: 5598 return (5); 5599 } 5600 } 5601 5602 static void 5603 ixl_send_vf_msg(struct ixl_pf *pf, struct ixl_vf *vf, uint16_t op, 5604 enum i40e_status_code status, void *msg, uint16_t len) 5605 { 5606 struct i40e_hw *hw; 5607 int global_vf_id; 5608 5609 hw = &pf->hw; 5610 global_vf_id = hw->func_caps.vf_base_id + vf->vf_num; 5611 5612 I40E_VC_DEBUG(pf, ixl_vc_opcode_level(op), 5613 "Sending msg (op=%s[%d], status=%d) to VF-%d\n", 5614 ixl_vc_opcode_str(op), op, status, vf->vf_num); 5615 5616 i40e_aq_send_msg_to_vf(hw, global_vf_id, op, status, msg, len, NULL); 5617 } 5618 5619 static void 5620 ixl_send_vf_ack(struct ixl_pf *pf, struct ixl_vf *vf, uint16_t op) 5621 { 5622 5623 ixl_send_vf_msg(pf, vf, op, I40E_SUCCESS, NULL, 0); 5624 } 5625 5626 static void 5627 ixl_send_vf_nack_msg(struct ixl_pf *pf, struct ixl_vf *vf, uint16_t op, 5628 enum i40e_status_code status, const char *file, int line) 5629 { 5630 5631 I40E_VC_DEBUG(pf, 1, 5632 "Sending NACK (op=%s[%d], err=%d) to VF-%d from %s:%d\n", 5633 ixl_vc_opcode_str(op), op, status, vf->vf_num, file, line); 5634 ixl_send_vf_msg(pf, vf, op, status, NULL, 0); 5635 } 5636 5637 static void 5638 ixl_vf_version_msg(struct ixl_pf *pf, struct ixl_vf *vf, void *msg, 5639 uint16_t msg_size) 5640 { 5641 struct i40e_virtchnl_version_info reply; 5642 5643 if (msg_size != sizeof(struct i40e_virtchnl_version_info)) { 5644 i40e_send_vf_nack(pf, vf, I40E_VIRTCHNL_OP_VERSION, 5645 I40E_ERR_PARAM); 5646 return; 5647 } 5648 5649 reply.major = I40E_VIRTCHNL_VERSION_MAJOR; 5650 reply.minor = I40E_VIRTCHNL_VERSION_MINOR; 5651 ixl_send_vf_msg(pf, vf, I40E_VIRTCHNL_OP_VERSION, I40E_SUCCESS, &reply, 5652 sizeof(reply)); 5653 } 5654 5655 static void 5656 ixl_vf_reset_msg(struct ixl_pf *pf, struct ixl_vf *vf, void *msg, 5657 uint16_t msg_size) 5658 { 5659 5660 if (msg_size != 0) { 5661 i40e_send_vf_nack(pf, vf, I40E_VIRTCHNL_OP_RESET_VF, 5662 I40E_ERR_PARAM); 5663 return; 5664 } 5665 5666 ixl_reset_vf(pf, vf); 5667 5668 /* No response to a reset message. */ 5669 } 5670 5671 static void 5672 ixl_vf_get_resources_msg(struct ixl_pf *pf, struct ixl_vf *vf, void *msg, 5673 uint16_t msg_size) 5674 { 5675 struct i40e_virtchnl_vf_resource reply; 5676 5677 if (msg_size != 0) { 5678 i40e_send_vf_nack(pf, vf, I40E_VIRTCHNL_OP_GET_VF_RESOURCES, 5679 I40E_ERR_PARAM); 5680 return; 5681 } 5682 5683 bzero(&reply, sizeof(reply)); 5684 5685 reply.vf_offload_flags = I40E_VIRTCHNL_VF_OFFLOAD_L2; 5686 5687 reply.num_vsis = 1; 5688 reply.num_queue_pairs = vf->vsi.num_queues; 5689 reply.max_vectors = pf->hw.func_caps.num_msix_vectors_vf; 5690 reply.vsi_res[0].vsi_id = vf->vsi.vsi_num; 5691 reply.vsi_res[0].vsi_type = I40E_VSI_SRIOV; 5692 reply.vsi_res[0].num_queue_pairs = vf->vsi.num_queues; 5693 memcpy(reply.vsi_res[0].default_mac_addr, vf->mac, ETHER_ADDR_LEN); 5694 5695 ixl_send_vf_msg(pf, vf, I40E_VIRTCHNL_OP_GET_VF_RESOURCES, 5696 I40E_SUCCESS, &reply, sizeof(reply)); 5697 } 5698 5699 static int 5700 ixl_vf_config_tx_queue(struct ixl_pf *pf, struct ixl_vf *vf, 5701 struct i40e_virtchnl_txq_info *info) 5702 { 5703 struct i40e_hw *hw; 5704 struct i40e_hmc_obj_txq txq; 5705 uint16_t global_queue_num, global_vf_num; 5706 enum i40e_status_code status; 5707 uint32_t qtx_ctl; 5708 5709 hw = &pf->hw; 5710 global_queue_num = vf->vsi.first_queue + info->queue_id; 5711 global_vf_num = hw->func_caps.vf_base_id + vf->vf_num; 5712 bzero(&txq, sizeof(txq)); 5713 5714 status = i40e_clear_lan_tx_queue_context(hw, global_queue_num); 5715 if (status != I40E_SUCCESS) 5716 return (EINVAL); 5717 5718 txq.base = info->dma_ring_addr / IXL_TX_CTX_BASE_UNITS; 5719 5720 txq.head_wb_ena = info->headwb_enabled; 5721 txq.head_wb_addr = info->dma_headwb_addr; 5722 txq.qlen = info->ring_len; 5723 txq.rdylist = le16_to_cpu(vf->vsi.info.qs_handle[0]); 5724 txq.rdylist_act = 0; 5725 5726 status = i40e_set_lan_tx_queue_context(hw, global_queue_num, &txq); 5727 if (status != I40E_SUCCESS) 5728 return (EINVAL); 5729 5730 qtx_ctl = I40E_QTX_CTL_VF_QUEUE | 5731 (hw->pf_id << I40E_QTX_CTL_PF_INDX_SHIFT) | 5732 (global_vf_num << I40E_QTX_CTL_VFVM_INDX_SHIFT); 5733 wr32(hw, I40E_QTX_CTL(global_queue_num), qtx_ctl); 5734 ixl_flush(hw); 5735 5736 return (0); 5737 } 5738 5739 static int 5740 ixl_vf_config_rx_queue(struct ixl_pf *pf, struct ixl_vf *vf, 5741 struct i40e_virtchnl_rxq_info *info) 5742 { 5743 struct i40e_hw *hw; 5744 struct i40e_hmc_obj_rxq rxq; 5745 uint16_t global_queue_num; 5746 enum i40e_status_code status; 5747 5748 hw = &pf->hw; 5749 global_queue_num = vf->vsi.first_queue + info->queue_id; 5750 bzero(&rxq, sizeof(rxq)); 5751 5752 if (info->databuffer_size > IXL_VF_MAX_BUFFER) 5753 return (EINVAL); 5754 5755 if (info->max_pkt_size > IXL_VF_MAX_FRAME || 5756 info->max_pkt_size < ETHER_MIN_LEN) 5757 return (EINVAL); 5758 5759 if (info->splithdr_enabled) { 5760 if (info->hdr_size > IXL_VF_MAX_HDR_BUFFER) 5761 return (EINVAL); 5762 5763 rxq.hsplit_0 = info->rx_split_pos & 5764 (I40E_HMC_OBJ_RX_HSPLIT_0_SPLIT_L2 | 5765 I40E_HMC_OBJ_RX_HSPLIT_0_SPLIT_IP | 5766 I40E_HMC_OBJ_RX_HSPLIT_0_SPLIT_TCP_UDP | 5767 I40E_HMC_OBJ_RX_HSPLIT_0_SPLIT_SCTP); 5768 rxq.hbuff = info->hdr_size >> I40E_RXQ_CTX_HBUFF_SHIFT; 5769 5770 rxq.dtype = 2; 5771 } 5772 5773 status = i40e_clear_lan_rx_queue_context(hw, global_queue_num); 5774 if (status != I40E_SUCCESS) 5775 return (EINVAL); 5776 5777 rxq.base = info->dma_ring_addr / IXL_RX_CTX_BASE_UNITS; 5778 rxq.qlen = info->ring_len; 5779 5780 rxq.dbuff = info->databuffer_size >> I40E_RXQ_CTX_DBUFF_SHIFT; 5781 5782 rxq.dsize = 1; 5783 rxq.crcstrip = 1; 5784 rxq.l2tsel = 1; 5785 5786 rxq.rxmax = info->max_pkt_size; 5787 rxq.tphrdesc_ena = 1; 5788 rxq.tphwdesc_ena = 1; 5789 rxq.tphdata_ena = 1; 5790 rxq.tphhead_ena = 1; 5791 rxq.lrxqthresh = 2; 5792 rxq.prefena = 1; 5793 5794 status = i40e_set_lan_rx_queue_context(hw, global_queue_num, &rxq); 5795 if (status != I40E_SUCCESS) 5796 return (EINVAL); 5797 5798 return (0); 5799 } 5800 5801 static void 5802 ixl_vf_config_vsi_msg(struct ixl_pf *pf, struct ixl_vf *vf, void *msg, 5803 uint16_t msg_size) 5804 { 5805 struct i40e_virtchnl_vsi_queue_config_info *info; 5806 struct i40e_virtchnl_queue_pair_info *pair; 5807 int i; 5808 5809 if (msg_size < sizeof(*info)) { 5810 i40e_send_vf_nack(pf, vf, I40E_VIRTCHNL_OP_CONFIG_VSI_QUEUES, 5811 I40E_ERR_PARAM); 5812 return; 5813 } 5814 5815 info = msg; 5816 if (info->num_queue_pairs == 0) { 5817 i40e_send_vf_nack(pf, vf, I40E_VIRTCHNL_OP_CONFIG_VSI_QUEUES, 5818 I40E_ERR_PARAM); 5819 return; 5820 } 5821 5822 if (msg_size != sizeof(*info) + info->num_queue_pairs * sizeof(*pair)) { 5823 i40e_send_vf_nack(pf, vf, I40E_VIRTCHNL_OP_CONFIG_VSI_QUEUES, 5824 I40E_ERR_PARAM); 5825 return; 5826 } 5827 5828 if (info->vsi_id != vf->vsi.vsi_num) { 5829 i40e_send_vf_nack(pf, vf, I40E_VIRTCHNL_OP_CONFIG_VSI_QUEUES, 5830 I40E_ERR_PARAM); 5831 return; 5832 } 5833 5834 for (i = 0; i < info->num_queue_pairs; i++) { 5835 pair = &info->qpair[i]; 5836 5837 if (pair->txq.vsi_id != vf->vsi.vsi_num || 5838 pair->rxq.vsi_id != vf->vsi.vsi_num || 5839 pair->txq.queue_id != pair->rxq.queue_id || 5840 pair->txq.queue_id >= vf->vsi.num_queues) { 5841 5842 i40e_send_vf_nack(pf, vf, 5843 I40E_VIRTCHNL_OP_CONFIG_VSI_QUEUES, I40E_ERR_PARAM); 5844 return; 5845 } 5846 5847 if (ixl_vf_config_tx_queue(pf, vf, &pair->txq) != 0) { 5848 i40e_send_vf_nack(pf, vf, 5849 I40E_VIRTCHNL_OP_CONFIG_VSI_QUEUES, I40E_ERR_PARAM); 5850 return; 5851 } 5852 5853 if (ixl_vf_config_rx_queue(pf, vf, &pair->rxq) != 0) { 5854 i40e_send_vf_nack(pf, vf, 5855 I40E_VIRTCHNL_OP_CONFIG_VSI_QUEUES, I40E_ERR_PARAM); 5856 return; 5857 } 5858 } 5859 5860 ixl_send_vf_ack(pf, vf, I40E_VIRTCHNL_OP_CONFIG_VSI_QUEUES); 5861 } 5862 5863 static void 5864 ixl_vf_set_qctl(struct ixl_pf *pf, 5865 const struct i40e_virtchnl_vector_map *vector, 5866 enum i40e_queue_type cur_type, uint16_t cur_queue, 5867 enum i40e_queue_type *last_type, uint16_t *last_queue) 5868 { 5869 uint32_t offset, qctl; 5870 uint16_t itr_indx; 5871 5872 if (cur_type == I40E_QUEUE_TYPE_RX) { 5873 offset = I40E_QINT_RQCTL(cur_queue); 5874 itr_indx = vector->rxitr_idx; 5875 } else { 5876 offset = I40E_QINT_TQCTL(cur_queue); 5877 itr_indx = vector->txitr_idx; 5878 } 5879 5880 qctl = htole32((vector->vector_id << I40E_QINT_RQCTL_MSIX_INDX_SHIFT) | 5881 (*last_type << I40E_QINT_RQCTL_NEXTQ_TYPE_SHIFT) | 5882 (*last_queue << I40E_QINT_RQCTL_NEXTQ_INDX_SHIFT) | 5883 I40E_QINT_RQCTL_CAUSE_ENA_MASK | 5884 (itr_indx << I40E_QINT_RQCTL_ITR_INDX_SHIFT)); 5885 5886 wr32(&pf->hw, offset, qctl); 5887 5888 *last_type = cur_type; 5889 *last_queue = cur_queue; 5890 } 5891 5892 static void 5893 ixl_vf_config_vector(struct ixl_pf *pf, struct ixl_vf *vf, 5894 const struct i40e_virtchnl_vector_map *vector) 5895 { 5896 struct i40e_hw *hw; 5897 u_int qindex; 5898 enum i40e_queue_type type, last_type; 5899 uint32_t lnklst_reg; 5900 uint16_t rxq_map, txq_map, cur_queue, last_queue; 5901 5902 hw = &pf->hw; 5903 5904 rxq_map = vector->rxq_map; 5905 txq_map = vector->txq_map; 5906 5907 last_queue = IXL_END_OF_INTR_LNKLST; 5908 last_type = I40E_QUEUE_TYPE_RX; 5909 5910 /* 5911 * The datasheet says to optimize performance, RX queues and TX queues 5912 * should be interleaved in the interrupt linked list, so we process 5913 * both at once here. 5914 */ 5915 while ((rxq_map != 0) || (txq_map != 0)) { 5916 if (txq_map != 0) { 5917 qindex = ffs(txq_map) - 1; 5918 type = I40E_QUEUE_TYPE_TX; 5919 cur_queue = vf->vsi.first_queue + qindex; 5920 ixl_vf_set_qctl(pf, vector, type, cur_queue, 5921 &last_type, &last_queue); 5922 txq_map &= ~(1 << qindex); 5923 } 5924 5925 if (rxq_map != 0) { 5926 qindex = ffs(rxq_map) - 1; 5927 type = I40E_QUEUE_TYPE_RX; 5928 cur_queue = vf->vsi.first_queue + qindex; 5929 ixl_vf_set_qctl(pf, vector, type, cur_queue, 5930 &last_type, &last_queue); 5931 rxq_map &= ~(1 << qindex); 5932 } 5933 } 5934 5935 if (vector->vector_id == 0) 5936 lnklst_reg = I40E_VPINT_LNKLST0(vf->vf_num); 5937 else 5938 lnklst_reg = IXL_VPINT_LNKLSTN_REG(hw, vector->vector_id, 5939 vf->vf_num); 5940 wr32(hw, lnklst_reg, 5941 (last_queue << I40E_VPINT_LNKLST0_FIRSTQ_INDX_SHIFT) | 5942 (last_type << I40E_VPINT_LNKLST0_FIRSTQ_TYPE_SHIFT)); 5943 5944 ixl_flush(hw); 5945 } 5946 5947 static void 5948 ixl_vf_config_irq_msg(struct ixl_pf *pf, struct ixl_vf *vf, void *msg, 5949 uint16_t msg_size) 5950 { 5951 struct i40e_virtchnl_irq_map_info *map; 5952 struct i40e_virtchnl_vector_map *vector; 5953 struct i40e_hw *hw; 5954 int i, largest_txq, largest_rxq; 5955 5956 hw = &pf->hw; 5957 5958 if (msg_size < sizeof(*map)) { 5959 i40e_send_vf_nack(pf, vf, I40E_VIRTCHNL_OP_CONFIG_IRQ_MAP, 5960 I40E_ERR_PARAM); 5961 return; 5962 } 5963 5964 map = msg; 5965 if (map->num_vectors == 0) { 5966 i40e_send_vf_nack(pf, vf, I40E_VIRTCHNL_OP_CONFIG_IRQ_MAP, 5967 I40E_ERR_PARAM); 5968 return; 5969 } 5970 5971 if (msg_size != sizeof(*map) + map->num_vectors * sizeof(*vector)) { 5972 i40e_send_vf_nack(pf, vf, I40E_VIRTCHNL_OP_CONFIG_IRQ_MAP, 5973 I40E_ERR_PARAM); 5974 return; 5975 } 5976 5977 for (i = 0; i < map->num_vectors; i++) { 5978 vector = &map->vecmap[i]; 5979 5980 if ((vector->vector_id >= hw->func_caps.num_msix_vectors_vf) || 5981 vector->vsi_id != vf->vsi.vsi_num) { 5982 i40e_send_vf_nack(pf, vf, 5983 I40E_VIRTCHNL_OP_CONFIG_IRQ_MAP, I40E_ERR_PARAM); 5984 return; 5985 } 5986 5987 if (vector->rxq_map != 0) { 5988 largest_rxq = fls(vector->rxq_map) - 1; 5989 if (largest_rxq >= vf->vsi.num_queues) { 5990 i40e_send_vf_nack(pf, vf, 5991 I40E_VIRTCHNL_OP_CONFIG_IRQ_MAP, 5992 I40E_ERR_PARAM); 5993 return; 5994 } 5995 } 5996 5997 if (vector->txq_map != 0) { 5998 largest_txq = fls(vector->txq_map) - 1; 5999 if (largest_txq >= vf->vsi.num_queues) { 6000 i40e_send_vf_nack(pf, vf, 6001 I40E_VIRTCHNL_OP_CONFIG_IRQ_MAP, 6002 I40E_ERR_PARAM); 6003 return; 6004 } 6005 } 6006 6007 if (vector->rxitr_idx > IXL_MAX_ITR_IDX || 6008 vector->txitr_idx > IXL_MAX_ITR_IDX) { 6009 i40e_send_vf_nack(pf, vf, 6010 I40E_VIRTCHNL_OP_CONFIG_IRQ_MAP, 6011 I40E_ERR_PARAM); 6012 return; 6013 } 6014 6015 ixl_vf_config_vector(pf, vf, vector); 6016 } 6017 6018 ixl_send_vf_ack(pf, vf, I40E_VIRTCHNL_OP_CONFIG_IRQ_MAP); 6019 } 6020 6021 static void 6022 ixl_vf_enable_queues_msg(struct ixl_pf *pf, struct ixl_vf *vf, void *msg, 6023 uint16_t msg_size) 6024 { 6025 struct i40e_virtchnl_queue_select *select; 6026 int error; 6027 6028 if (msg_size != sizeof(*select)) { 6029 i40e_send_vf_nack(pf, vf, I40E_VIRTCHNL_OP_ENABLE_QUEUES, 6030 I40E_ERR_PARAM); 6031 return; 6032 } 6033 6034 select = msg; 6035 if (select->vsi_id != vf->vsi.vsi_num || 6036 select->rx_queues == 0 || select->tx_queues == 0) { 6037 i40e_send_vf_nack(pf, vf, I40E_VIRTCHNL_OP_ENABLE_QUEUES, 6038 I40E_ERR_PARAM); 6039 return; 6040 } 6041 6042 error = ixl_enable_rings(&vf->vsi); 6043 if (error) { 6044 i40e_send_vf_nack(pf, vf, I40E_VIRTCHNL_OP_ENABLE_QUEUES, 6045 I40E_ERR_TIMEOUT); 6046 return; 6047 } 6048 6049 ixl_send_vf_ack(pf, vf, I40E_VIRTCHNL_OP_ENABLE_QUEUES); 6050 } 6051 6052 static void 6053 ixl_vf_disable_queues_msg(struct ixl_pf *pf, struct ixl_vf *vf, 6054 void *msg, uint16_t msg_size) 6055 { 6056 struct i40e_virtchnl_queue_select *select; 6057 int error; 6058 6059 if (msg_size != sizeof(*select)) { 6060 i40e_send_vf_nack(pf, vf, I40E_VIRTCHNL_OP_DISABLE_QUEUES, 6061 I40E_ERR_PARAM); 6062 return; 6063 } 6064 6065 select = msg; 6066 if (select->vsi_id != vf->vsi.vsi_num || 6067 select->rx_queues == 0 || select->tx_queues == 0) { 6068 i40e_send_vf_nack(pf, vf, I40E_VIRTCHNL_OP_DISABLE_QUEUES, 6069 I40E_ERR_PARAM); 6070 return; 6071 } 6072 6073 error = ixl_disable_rings(&vf->vsi); 6074 if (error) { 6075 i40e_send_vf_nack(pf, vf, I40E_VIRTCHNL_OP_DISABLE_QUEUES, 6076 I40E_ERR_TIMEOUT); 6077 return; 6078 } 6079 6080 ixl_send_vf_ack(pf, vf, I40E_VIRTCHNL_OP_DISABLE_QUEUES); 6081 } 6082 6083 static boolean_t 6084 ixl_zero_mac(const uint8_t *addr) 6085 { 6086 uint8_t zero[ETHER_ADDR_LEN] = {0, 0, 0, 0, 0, 0}; 6087 6088 return (cmp_etheraddr(addr, zero)); 6089 } 6090 6091 static boolean_t 6092 ixl_bcast_mac(const uint8_t *addr) 6093 { 6094 6095 return (cmp_etheraddr(addr, ixl_bcast_addr)); 6096 } 6097 6098 static int 6099 ixl_vf_mac_valid(struct ixl_vf *vf, const uint8_t *addr) 6100 { 6101 6102 if (ixl_zero_mac(addr) || ixl_bcast_mac(addr)) 6103 return (EINVAL); 6104 6105 /* 6106 * If the VF is not allowed to change its MAC address, don't let it 6107 * set a MAC filter for an address that is not a multicast address and 6108 * is not its assigned MAC. 6109 */ 6110 if (!(vf->vf_flags & VF_FLAG_SET_MAC_CAP) && 6111 !(ETHER_IS_MULTICAST(addr) || cmp_etheraddr(addr, vf->mac))) 6112 return (EPERM); 6113 6114 return (0); 6115 } 6116 6117 static void 6118 ixl_vf_add_mac_msg(struct ixl_pf *pf, struct ixl_vf *vf, void *msg, 6119 uint16_t msg_size) 6120 { 6121 struct i40e_virtchnl_ether_addr_list *addr_list; 6122 struct i40e_virtchnl_ether_addr *addr; 6123 struct ixl_vsi *vsi; 6124 int i; 6125 size_t expected_size; 6126 6127 vsi = &vf->vsi; 6128 6129 if (msg_size < sizeof(*addr_list)) { 6130 i40e_send_vf_nack(pf, vf, I40E_VIRTCHNL_OP_ADD_ETHER_ADDRESS, 6131 I40E_ERR_PARAM); 6132 return; 6133 } 6134 6135 addr_list = msg; 6136 expected_size = sizeof(*addr_list) + 6137 addr_list->num_elements * sizeof(*addr); 6138 6139 if (addr_list->num_elements == 0 || 6140 addr_list->vsi_id != vsi->vsi_num || 6141 msg_size != expected_size) { 6142 i40e_send_vf_nack(pf, vf, I40E_VIRTCHNL_OP_ADD_ETHER_ADDRESS, 6143 I40E_ERR_PARAM); 6144 return; 6145 } 6146 6147 for (i = 0; i < addr_list->num_elements; i++) { 6148 if (ixl_vf_mac_valid(vf, addr_list->list[i].addr) != 0) { 6149 i40e_send_vf_nack(pf, vf, 6150 I40E_VIRTCHNL_OP_ADD_ETHER_ADDRESS, I40E_ERR_PARAM); 6151 return; 6152 } 6153 } 6154 6155 for (i = 0; i < addr_list->num_elements; i++) { 6156 addr = &addr_list->list[i]; 6157 ixl_add_filter(vsi, addr->addr, IXL_VLAN_ANY); 6158 } 6159 6160 ixl_send_vf_ack(pf, vf, I40E_VIRTCHNL_OP_ADD_ETHER_ADDRESS); 6161 } 6162 6163 static void 6164 ixl_vf_del_mac_msg(struct ixl_pf *pf, struct ixl_vf *vf, void *msg, 6165 uint16_t msg_size) 6166 { 6167 struct i40e_virtchnl_ether_addr_list *addr_list; 6168 struct i40e_virtchnl_ether_addr *addr; 6169 size_t expected_size; 6170 int i; 6171 6172 if (msg_size < sizeof(*addr_list)) { 6173 i40e_send_vf_nack(pf, vf, I40E_VIRTCHNL_OP_ADD_ETHER_ADDRESS, 6174 I40E_ERR_PARAM); 6175 return; 6176 } 6177 6178 addr_list = msg; 6179 expected_size = sizeof(*addr_list) + 6180 addr_list->num_elements * sizeof(*addr); 6181 6182 if (addr_list->num_elements == 0 || 6183 addr_list->vsi_id != vf->vsi.vsi_num || 6184 msg_size != expected_size) { 6185 i40e_send_vf_nack(pf, vf, I40E_VIRTCHNL_OP_ADD_ETHER_ADDRESS, 6186 I40E_ERR_PARAM); 6187 return; 6188 } 6189 6190 for (i = 0; i < addr_list->num_elements; i++) { 6191 addr = &addr_list->list[i]; 6192 if (ixl_zero_mac(addr->addr) || ixl_bcast_mac(addr->addr)) { 6193 i40e_send_vf_nack(pf, vf, 6194 I40E_VIRTCHNL_OP_ADD_ETHER_ADDRESS, I40E_ERR_PARAM); 6195 return; 6196 } 6197 } 6198 6199 for (i = 0; i < addr_list->num_elements; i++) { 6200 addr = &addr_list->list[i]; 6201 ixl_del_filter(&vf->vsi, addr->addr, IXL_VLAN_ANY); 6202 } 6203 6204 ixl_send_vf_ack(pf, vf, I40E_VIRTCHNL_OP_DEL_ETHER_ADDRESS); 6205 } 6206 6207 static enum i40e_status_code 6208 ixl_vf_enable_vlan_strip(struct ixl_pf *pf, struct ixl_vf *vf) 6209 { 6210 struct i40e_vsi_context vsi_ctx; 6211 6212 vsi_ctx.seid = vf->vsi.seid; 6213 6214 bzero(&vsi_ctx.info, sizeof(vsi_ctx.info)); 6215 vsi_ctx.info.valid_sections = htole16(I40E_AQ_VSI_PROP_VLAN_VALID); 6216 vsi_ctx.info.port_vlan_flags = I40E_AQ_VSI_PVLAN_MODE_ALL | 6217 I40E_AQ_VSI_PVLAN_EMOD_STR_BOTH; 6218 return (i40e_aq_update_vsi_params(&pf->hw, &vsi_ctx, NULL)); 6219 } 6220 6221 static void 6222 ixl_vf_add_vlan_msg(struct ixl_pf *pf, struct ixl_vf *vf, void *msg, 6223 uint16_t msg_size) 6224 { 6225 struct i40e_virtchnl_vlan_filter_list *filter_list; 6226 enum i40e_status_code code; 6227 size_t expected_size; 6228 int i; 6229 6230 if (msg_size < sizeof(*filter_list)) { 6231 i40e_send_vf_nack(pf, vf, I40E_VIRTCHNL_OP_ADD_VLAN, 6232 I40E_ERR_PARAM); 6233 return; 6234 } 6235 6236 filter_list = msg; 6237 expected_size = sizeof(*filter_list) + 6238 filter_list->num_elements * sizeof(uint16_t); 6239 if (filter_list->num_elements == 0 || 6240 filter_list->vsi_id != vf->vsi.vsi_num || 6241 msg_size != expected_size) { 6242 i40e_send_vf_nack(pf, vf, I40E_VIRTCHNL_OP_ADD_VLAN, 6243 I40E_ERR_PARAM); 6244 return; 6245 } 6246 6247 if (!(vf->vf_flags & VF_FLAG_VLAN_CAP)) { 6248 i40e_send_vf_nack(pf, vf, I40E_VIRTCHNL_OP_ADD_VLAN, 6249 I40E_ERR_PARAM); 6250 return; 6251 } 6252 6253 for (i = 0; i < filter_list->num_elements; i++) { 6254 if (filter_list->vlan_id[i] > EVL_VLID_MASK) { 6255 i40e_send_vf_nack(pf, vf, I40E_VIRTCHNL_OP_ADD_VLAN, 6256 I40E_ERR_PARAM); 6257 return; 6258 } 6259 } 6260 6261 code = ixl_vf_enable_vlan_strip(pf, vf); 6262 if (code != I40E_SUCCESS) { 6263 i40e_send_vf_nack(pf, vf, I40E_VIRTCHNL_OP_ADD_VLAN, 6264 I40E_ERR_PARAM); 6265 } 6266 6267 for (i = 0; i < filter_list->num_elements; i++) 6268 ixl_add_filter(&vf->vsi, vf->mac, filter_list->vlan_id[i]); 6269 6270 ixl_send_vf_ack(pf, vf, I40E_VIRTCHNL_OP_ADD_VLAN); 6271 } 6272 6273 static void 6274 ixl_vf_del_vlan_msg(struct ixl_pf *pf, struct ixl_vf *vf, void *msg, 6275 uint16_t msg_size) 6276 { 6277 struct i40e_virtchnl_vlan_filter_list *filter_list; 6278 int i; 6279 size_t expected_size; 6280 6281 if (msg_size < sizeof(*filter_list)) { 6282 i40e_send_vf_nack(pf, vf, I40E_VIRTCHNL_OP_DEL_VLAN, 6283 I40E_ERR_PARAM); 6284 return; 6285 } 6286 6287 filter_list = msg; 6288 expected_size = sizeof(*filter_list) + 6289 filter_list->num_elements * sizeof(uint16_t); 6290 if (filter_list->num_elements == 0 || 6291 filter_list->vsi_id != vf->vsi.vsi_num || 6292 msg_size != expected_size) { 6293 i40e_send_vf_nack(pf, vf, I40E_VIRTCHNL_OP_DEL_VLAN, 6294 I40E_ERR_PARAM); 6295 return; 6296 } 6297 6298 for (i = 0; i < filter_list->num_elements; i++) { 6299 if (filter_list->vlan_id[i] > EVL_VLID_MASK) { 6300 i40e_send_vf_nack(pf, vf, I40E_VIRTCHNL_OP_ADD_VLAN, 6301 I40E_ERR_PARAM); 6302 return; 6303 } 6304 } 6305 6306 if (!(vf->vf_flags & VF_FLAG_VLAN_CAP)) { 6307 i40e_send_vf_nack(pf, vf, I40E_VIRTCHNL_OP_ADD_VLAN, 6308 I40E_ERR_PARAM); 6309 return; 6310 } 6311 6312 for (i = 0; i < filter_list->num_elements; i++) 6313 ixl_del_filter(&vf->vsi, vf->mac, filter_list->vlan_id[i]); 6314 6315 ixl_send_vf_ack(pf, vf, I40E_VIRTCHNL_OP_DEL_VLAN); 6316 } 6317 6318 static void 6319 ixl_vf_config_promisc_msg(struct ixl_pf *pf, struct ixl_vf *vf, 6320 void *msg, uint16_t msg_size) 6321 { 6322 struct i40e_virtchnl_promisc_info *info; 6323 enum i40e_status_code code; 6324 6325 if (msg_size != sizeof(*info)) { 6326 i40e_send_vf_nack(pf, vf, 6327 I40E_VIRTCHNL_OP_CONFIG_PROMISCUOUS_MODE, I40E_ERR_PARAM); 6328 return; 6329 } 6330 6331 if (!vf->vf_flags & VF_FLAG_PROMISC_CAP) { 6332 i40e_send_vf_nack(pf, vf, 6333 I40E_VIRTCHNL_OP_CONFIG_PROMISCUOUS_MODE, I40E_ERR_PARAM); 6334 return; 6335 } 6336 6337 info = msg; 6338 if (info->vsi_id != vf->vsi.vsi_num) { 6339 i40e_send_vf_nack(pf, vf, 6340 I40E_VIRTCHNL_OP_CONFIG_PROMISCUOUS_MODE, I40E_ERR_PARAM); 6341 return; 6342 } 6343 6344 code = i40e_aq_set_vsi_unicast_promiscuous(&pf->hw, info->vsi_id, 6345 info->flags & I40E_FLAG_VF_UNICAST_PROMISC, NULL); 6346 if (code != I40E_SUCCESS) { 6347 i40e_send_vf_nack(pf, vf, 6348 I40E_VIRTCHNL_OP_CONFIG_PROMISCUOUS_MODE, code); 6349 return; 6350 } 6351 6352 code = i40e_aq_set_vsi_multicast_promiscuous(&pf->hw, info->vsi_id, 6353 info->flags & I40E_FLAG_VF_MULTICAST_PROMISC, NULL); 6354 if (code != I40E_SUCCESS) { 6355 i40e_send_vf_nack(pf, vf, 6356 I40E_VIRTCHNL_OP_CONFIG_PROMISCUOUS_MODE, code); 6357 return; 6358 } 6359 6360 ixl_send_vf_ack(pf, vf, I40E_VIRTCHNL_OP_CONFIG_PROMISCUOUS_MODE); 6361 } 6362 6363 static void 6364 ixl_vf_get_stats_msg(struct ixl_pf *pf, struct ixl_vf *vf, void *msg, 6365 uint16_t msg_size) 6366 { 6367 struct i40e_virtchnl_queue_select *queue; 6368 6369 if (msg_size != sizeof(*queue)) { 6370 i40e_send_vf_nack(pf, vf, I40E_VIRTCHNL_OP_GET_STATS, 6371 I40E_ERR_PARAM); 6372 return; 6373 } 6374 6375 queue = msg; 6376 if (queue->vsi_id != vf->vsi.vsi_num) { 6377 i40e_send_vf_nack(pf, vf, I40E_VIRTCHNL_OP_GET_STATS, 6378 I40E_ERR_PARAM); 6379 return; 6380 } 6381 6382 ixl_update_eth_stats(&vf->vsi); 6383 6384 ixl_send_vf_msg(pf, vf, I40E_VIRTCHNL_OP_GET_STATS, 6385 I40E_SUCCESS, &vf->vsi.eth_stats, sizeof(vf->vsi.eth_stats)); 6386 } 6387 6388 static void 6389 ixl_handle_vf_msg(struct ixl_pf *pf, struct i40e_arq_event_info *event) 6390 { 6391 struct ixl_vf *vf; 6392 void *msg; 6393 uint16_t vf_num, msg_size; 6394 uint32_t opcode; 6395 6396 vf_num = le16toh(event->desc.retval) - pf->hw.func_caps.vf_base_id; 6397 opcode = le32toh(event->desc.cookie_high); 6398 6399 if (vf_num >= pf->num_vfs) { 6400 device_printf(pf->dev, "Got msg from illegal VF: %d\n", vf_num); 6401 return; 6402 } 6403 6404 vf = &pf->vfs[vf_num]; 6405 msg = event->msg_buf; 6406 msg_size = event->msg_len; 6407 6408 I40E_VC_DEBUG(pf, ixl_vc_opcode_level(opcode), 6409 "Got msg %s(%d) from VF-%d of size %d\n", 6410 ixl_vc_opcode_str(opcode), opcode, vf_num, msg_size); 6411 6412 switch (opcode) { 6413 case I40E_VIRTCHNL_OP_VERSION: 6414 ixl_vf_version_msg(pf, vf, msg, msg_size); 6415 break; 6416 case I40E_VIRTCHNL_OP_RESET_VF: 6417 ixl_vf_reset_msg(pf, vf, msg, msg_size); 6418 break; 6419 case I40E_VIRTCHNL_OP_GET_VF_RESOURCES: 6420 ixl_vf_get_resources_msg(pf, vf, msg, msg_size); 6421 break; 6422 case I40E_VIRTCHNL_OP_CONFIG_VSI_QUEUES: 6423 ixl_vf_config_vsi_msg(pf, vf, msg, msg_size); 6424 break; 6425 case I40E_VIRTCHNL_OP_CONFIG_IRQ_MAP: 6426 ixl_vf_config_irq_msg(pf, vf, msg, msg_size); 6427 break; 6428 case I40E_VIRTCHNL_OP_ENABLE_QUEUES: 6429 ixl_vf_enable_queues_msg(pf, vf, msg, msg_size); 6430 break; 6431 case I40E_VIRTCHNL_OP_DISABLE_QUEUES: 6432 ixl_vf_disable_queues_msg(pf, vf, msg, msg_size); 6433 break; 6434 case I40E_VIRTCHNL_OP_ADD_ETHER_ADDRESS: 6435 ixl_vf_add_mac_msg(pf, vf, msg, msg_size); 6436 break; 6437 case I40E_VIRTCHNL_OP_DEL_ETHER_ADDRESS: 6438 ixl_vf_del_mac_msg(pf, vf, msg, msg_size); 6439 break; 6440 case I40E_VIRTCHNL_OP_ADD_VLAN: 6441 ixl_vf_add_vlan_msg(pf, vf, msg, msg_size); 6442 break; 6443 case I40E_VIRTCHNL_OP_DEL_VLAN: 6444 ixl_vf_del_vlan_msg(pf, vf, msg, msg_size); 6445 break; 6446 case I40E_VIRTCHNL_OP_CONFIG_PROMISCUOUS_MODE: 6447 ixl_vf_config_promisc_msg(pf, vf, msg, msg_size); 6448 break; 6449 case I40E_VIRTCHNL_OP_GET_STATS: 6450 ixl_vf_get_stats_msg(pf, vf, msg, msg_size); 6451 break; 6452 6453 /* These two opcodes have been superseded by CONFIG_VSI_QUEUES. */ 6454 case I40E_VIRTCHNL_OP_CONFIG_TX_QUEUE: 6455 case I40E_VIRTCHNL_OP_CONFIG_RX_QUEUE: 6456 default: 6457 i40e_send_vf_nack(pf, vf, opcode, I40E_ERR_NOT_IMPLEMENTED); 6458 break; 6459 } 6460 } 6461 6462 /* Handle any VFs that have reset themselves via a Function Level Reset(FLR). */ 6463 static void 6464 ixl_handle_vflr(void *arg, int pending) 6465 { 6466 struct ixl_pf *pf; 6467 struct i40e_hw *hw; 6468 uint16_t global_vf_num; 6469 uint32_t vflrstat_index, vflrstat_mask, vflrstat, icr0; 6470 int i; 6471 6472 pf = arg; 6473 hw = &pf->hw; 6474 6475 IXL_PF_LOCK(pf); 6476 for (i = 0; i < pf->num_vfs; i++) { 6477 global_vf_num = hw->func_caps.vf_base_id + i; 6478 6479 vflrstat_index = IXL_GLGEN_VFLRSTAT_INDEX(global_vf_num); 6480 vflrstat_mask = IXL_GLGEN_VFLRSTAT_MASK(global_vf_num); 6481 vflrstat = rd32(hw, I40E_GLGEN_VFLRSTAT(vflrstat_index)); 6482 if (vflrstat & vflrstat_mask) { 6483 wr32(hw, I40E_GLGEN_VFLRSTAT(vflrstat_index), 6484 vflrstat_mask); 6485 6486 ixl_reinit_vf(pf, &pf->vfs[i]); 6487 } 6488 } 6489 6490 icr0 = rd32(hw, I40E_PFINT_ICR0_ENA); 6491 icr0 |= I40E_PFINT_ICR0_ENA_VFLR_MASK; 6492 wr32(hw, I40E_PFINT_ICR0_ENA, icr0); 6493 ixl_flush(hw); 6494 6495 IXL_PF_UNLOCK(pf); 6496 } 6497 6498 static int 6499 ixl_adminq_err_to_errno(enum i40e_admin_queue_err err) 6500 { 6501 6502 switch (err) { 6503 case I40E_AQ_RC_EPERM: 6504 return (EPERM); 6505 case I40E_AQ_RC_ENOENT: 6506 return (ENOENT); 6507 case I40E_AQ_RC_ESRCH: 6508 return (ESRCH); 6509 case I40E_AQ_RC_EINTR: 6510 return (EINTR); 6511 case I40E_AQ_RC_EIO: 6512 return (EIO); 6513 case I40E_AQ_RC_ENXIO: 6514 return (ENXIO); 6515 case I40E_AQ_RC_E2BIG: 6516 return (E2BIG); 6517 case I40E_AQ_RC_EAGAIN: 6518 return (EAGAIN); 6519 case I40E_AQ_RC_ENOMEM: 6520 return (ENOMEM); 6521 case I40E_AQ_RC_EACCES: 6522 return (EACCES); 6523 case I40E_AQ_RC_EFAULT: 6524 return (EFAULT); 6525 case I40E_AQ_RC_EBUSY: 6526 return (EBUSY); 6527 case I40E_AQ_RC_EEXIST: 6528 return (EEXIST); 6529 case I40E_AQ_RC_EINVAL: 6530 return (EINVAL); 6531 case I40E_AQ_RC_ENOTTY: 6532 return (ENOTTY); 6533 case I40E_AQ_RC_ENOSPC: 6534 return (ENOSPC); 6535 case I40E_AQ_RC_ENOSYS: 6536 return (ENOSYS); 6537 case I40E_AQ_RC_ERANGE: 6538 return (ERANGE); 6539 case I40E_AQ_RC_EFLUSHED: 6540 return (EINVAL); /* No exact equivalent in errno.h */ 6541 case I40E_AQ_RC_BAD_ADDR: 6542 return (EFAULT); 6543 case I40E_AQ_RC_EMODE: 6544 return (EPERM); 6545 case I40E_AQ_RC_EFBIG: 6546 return (EFBIG); 6547 default: 6548 return (EINVAL); 6549 } 6550 } 6551 6552 static int 6553 ixl_iov_init(device_t dev, uint16_t num_vfs, const nvlist_t *params) 6554 { 6555 struct ixl_pf *pf; 6556 struct i40e_hw *hw; 6557 struct ixl_vsi *pf_vsi; 6558 enum i40e_status_code ret; 6559 int i, error; 6560 6561 pf = device_get_softc(dev); 6562 hw = &pf->hw; 6563 pf_vsi = &pf->vsi; 6564 6565 IXL_PF_LOCK(pf); 6566 pf->vfs = malloc(sizeof(struct ixl_vf) * num_vfs, M_IXL, M_NOWAIT | 6567 M_ZERO); 6568 6569 if (pf->vfs == NULL) { 6570 error = ENOMEM; 6571 goto fail; 6572 } 6573 6574 for (i = 0; i < num_vfs; i++) 6575 sysctl_ctx_init(&pf->vfs[i].ctx); 6576 6577 ret = i40e_aq_add_veb(hw, pf_vsi->uplink_seid, pf_vsi->seid, 6578 1, FALSE, FALSE, &pf->veb_seid, NULL); 6579 if (ret != I40E_SUCCESS) { 6580 error = ixl_adminq_err_to_errno(hw->aq.asq_last_status); 6581 device_printf(dev, "add_veb failed; code=%d error=%d", ret, 6582 error); 6583 goto fail; 6584 } 6585 6586 ixl_configure_msix(pf); 6587 ixl_enable_adminq(hw); 6588 6589 pf->num_vfs = num_vfs; 6590 IXL_PF_UNLOCK(pf); 6591 return (0); 6592 6593 fail: 6594 free(pf->vfs, M_IXL); 6595 pf->vfs = NULL; 6596 IXL_PF_UNLOCK(pf); 6597 return (error); 6598 } 6599 6600 static void 6601 ixl_iov_uninit(device_t dev) 6602 { 6603 struct ixl_pf *pf; 6604 struct i40e_hw *hw; 6605 struct ixl_vsi *vsi; 6606 struct ifnet *ifp; 6607 struct ixl_vf *vfs; 6608 int i, num_vfs; 6609 6610 pf = device_get_softc(dev); 6611 hw = &pf->hw; 6612 vsi = &pf->vsi; 6613 ifp = vsi->ifp; 6614 6615 IXL_PF_LOCK(pf); 6616 for (i = 0; i < pf->num_vfs; i++) { 6617 if (pf->vfs[i].vsi.seid != 0) 6618 i40e_aq_delete_element(hw, pf->vfs[i].vsi.seid, NULL); 6619 } 6620 6621 if (pf->veb_seid != 0) { 6622 i40e_aq_delete_element(hw, pf->veb_seid, NULL); 6623 pf->veb_seid = 0; 6624 } 6625 6626 if ((if_getdrvflags(ifp) & IFF_DRV_RUNNING) == 0) 6627 ixl_disable_intr(vsi); 6628 6629 vfs = pf->vfs; 6630 num_vfs = pf->num_vfs; 6631 6632 pf->vfs = NULL; 6633 pf->num_vfs = 0; 6634 IXL_PF_UNLOCK(pf); 6635 6636 /* Do this after the unlock as sysctl_ctx_free might sleep. */ 6637 for (i = 0; i < num_vfs; i++) 6638 sysctl_ctx_free(&vfs[i].ctx); 6639 free(vfs, M_IXL); 6640 } 6641 6642 static int 6643 ixl_add_vf(device_t dev, uint16_t vfnum, const nvlist_t *params) 6644 { 6645 char sysctl_name[QUEUE_NAME_LEN]; 6646 struct ixl_pf *pf; 6647 struct ixl_vf *vf; 6648 const void *mac; 6649 size_t size; 6650 int error; 6651 6652 pf = device_get_softc(dev); 6653 vf = &pf->vfs[vfnum]; 6654 6655 IXL_PF_LOCK(pf); 6656 vf->vf_num = vfnum; 6657 6658 vf->vsi.back = pf; 6659 vf->vf_flags = VF_FLAG_ENABLED; 6660 SLIST_INIT(&vf->vsi.ftl); 6661 6662 error = ixl_vf_setup_vsi(pf, vf); 6663 if (error != 0) 6664 goto out; 6665 6666 if (nvlist_exists_binary(params, "mac-addr")) { 6667 mac = nvlist_get_binary(params, "mac-addr", &size); 6668 bcopy(mac, vf->mac, ETHER_ADDR_LEN); 6669 6670 if (nvlist_get_bool(params, "allow-set-mac")) 6671 vf->vf_flags |= VF_FLAG_SET_MAC_CAP; 6672 } else 6673 /* 6674 * If the administrator has not specified a MAC address then 6675 * we must allow the VF to choose one. 6676 */ 6677 vf->vf_flags |= VF_FLAG_SET_MAC_CAP; 6678 6679 if (nvlist_get_bool(params, "mac-anti-spoof")) 6680 vf->vf_flags |= VF_FLAG_MAC_ANTI_SPOOF; 6681 6682 if (nvlist_get_bool(params, "allow-promisc")) 6683 vf->vf_flags |= VF_FLAG_PROMISC_CAP; 6684 6685 vf->vf_flags |= VF_FLAG_VLAN_CAP; 6686 6687 ixl_reset_vf(pf, vf); 6688 out: 6689 IXL_PF_UNLOCK(pf); 6690 if (error == 0) { 6691 snprintf(sysctl_name, sizeof(sysctl_name), "vf%d", vfnum); 6692 ixl_add_vsi_sysctls(pf, &vf->vsi, &vf->ctx, sysctl_name); 6693 } 6694 6695 return (error); 6696 } 6697 #endif /* PCI_IOV */ 6698