| /src/sys/dev/vmware/vmxnet3/ |
| H A D | if_vmx.c | 330 if_softc_ctx_t scctx; in vmxnet3_attach_pre() local 343 scctx = sc->vmx_scctx; in vmxnet3_attach_pre() 345 scctx->isc_tx_nsegments = VMXNET3_TX_MAXSEGS; in vmxnet3_attach_pre() 346 scctx->isc_tx_tso_segments_max = VMXNET3_TX_MAXSEGS; in vmxnet3_attach_pre() 348 scctx->isc_tx_tso_size_max = VMXNET3_TSO_MAXSIZE; in vmxnet3_attach_pre() 349 scctx->isc_tx_tso_segsize_max = VMXNET3_TX_MAXSEGSIZE; in vmxnet3_attach_pre() 350 scctx->isc_txrx = &vmxnet3_txrx; in vmxnet3_attach_pre() 353 if (scctx->isc_nrxqsets == 0) in vmxnet3_attach_pre() 354 scctx->isc_nrxqsets = VMXNET3_DEF_RX_QUEUES; in vmxnet3_attach_pre() 355 scctx->isc_nrxqsets = trunc_powerof2(scctx->isc_nrxqsets); in vmxnet3_attach_pre() [all …]
|
| /src/sys/dev/enic/ |
| H A D | if_enic.c | 241 if_softc_ctx_t scctx; in enic_allocate_msix() local 250 scctx = softc->scctx; in enic_allocate_msix() 260 queues = imin(queues, scctx->isc_nrxqsets); in enic_allocate_msix() 261 queues = imin(queues, scctx->isc_ntxqsets); in enic_allocate_msix() 263 scctx->isc_nrxqsets = queues; in enic_allocate_msix() 264 scctx->isc_ntxqsets = queues; in enic_allocate_msix() 287 scctx->isc_intr = IFLIB_INTR_MSIX; in enic_allocate_msix() 288 scctx->isc_vectors = vectors; in enic_allocate_msix() 334 if_softc_ctx_t scctx; in enic_attach_pre() local 353 softc->scctx = iflib_get_softc_ctx(ctx); in enic_attach_pre() [all …]
|
| H A D | enic_txrx.c | 106 if_softc_ctx_t scctx = softc->scctx; in enic_isc_txd_encap() local 116 if ((scctx->isc_capenable & IFCAP_RXCSUM) != 0) in enic_isc_txd_encap() 391 if_softc_ctx_t scctx; in vnic_rq_service() local 403 scctx = rq->vdev->softc->scctx; in vnic_rq_service() 429 if ((scctx->isc_capenable & IFCAP_RXCSUM) != 0) in vnic_rq_service()
|
| /src/sys/dev/e1000/ |
| H A D | em_txrx.c | 92 if_softc_ctx_t scctx = sc->shared; in em_dump_rs() local 100 ntxd = scctx->isc_ntxd[0]; in em_dump_rs() 138 if_softc_ctx_t scctx = sc->shared; in em_tso_setup() local 214 if (++cur == scctx->isc_ntxd[0]) { in em_tso_setup() 245 if_softc_ctx_t scctx = sc->shared; in em_transmit_checksum_setup() local 329 if (++cur == scctx->isc_ntxd[0]) { in em_transmit_checksum_setup() 345 if_softc_ctx_t scctx = sc->shared; in em_isc_txd_encap() local 362 ntxd = scctx->isc_ntxd[0]; in em_isc_txd_encap() 417 if (++i == scctx->isc_ntxd[0]) in em_isc_txd_encap() 427 if (++i == scctx->isc_ntxd[0]) in em_isc_txd_encap() [all …]
|
| H A D | igb_txrx.c | 236 if_softc_ctx_t scctx = sc->shared; in igb_isc_txd_encap() local 255 ntxd = scctx->isc_ntxd[0]; in igb_isc_txd_encap() 259 if (i == scctx->isc_ntxd[0]) in igb_isc_txd_encap() 279 if (++i == scctx->isc_ntxd[0]) { in igb_isc_txd_encap() 313 if_softc_ctx_t scctx = sc->shared; in igb_isc_txd_credits_update() local 339 ntxd = scctx->isc_ntxd[0]; in igb_isc_txd_credits_update() 366 if_softc_ctx_t scctx = sc->shared; in igb_isc_rxd_refill() local 384 if (++next_pidx == scctx->isc_nrxd[0]) in igb_isc_rxd_refill() 404 if_softc_ctx_t scctx = sc->shared; in igb_isc_rxd_available() local 411 for (cnt = 0, i = idx; cnt < scctx->isc_nrxd[0] && cnt <= budget;) { in igb_isc_rxd_available() [all …]
|
| H A D | if_em.c | 853 if_softc_ctx_t scctx = sc->shared; in em_get_regs() local 856 int ntxd = scctx->isc_ntxd[0]; in em_get_regs() 857 int nrxd = scctx->isc_nrxd[0]; in em_get_regs() 960 if_softc_ctx_t scctx; in em_if_attach_pre() local 973 scctx = sc->shared = iflib_get_softc_ctx(ctx); in em_if_attach_pre() 1038 scctx->isc_tx_nsegments = EM_MAX_SCATTER; in em_if_attach_pre() 1039 scctx->isc_nrxqsets_max = in em_if_attach_pre() 1040 scctx->isc_ntxqsets_max = em_set_num_queues(ctx); in em_if_attach_pre() 1043 scctx->isc_ntxqsets_max); in em_if_attach_pre() 1046 scctx->isc_txqsizes[0] = roundup2(scctx->isc_ntxd[0] * in em_if_attach_pre() [all …]
|
| /src/sys/dev/iavf/ |
| H A D | iavf_vc_iflib.c | 57 if_softc_ctx_t scctx = iflib_get_softc_ctx(vsi->ctx); in iavf_configure_queues() local 90 vqpi->txq.ring_len = scctx->isc_ntxd[0]; in iavf_configure_queues() 99 sizeof(struct iavf_tx_desc) * scctx->isc_ntxd[0]; in iavf_configure_queues() 104 vqpi->rxq.ring_len = scctx->isc_nrxd[0]; in iavf_configure_queues() 106 vqpi->rxq.max_pkt_size = scctx->isc_max_frame_size; in iavf_configure_queues() 134 if_softc_ctx_t scctx = vsi->shared; in iavf_map_queues() local 138 MPASS(scctx->isc_vectors > 1); in iavf_map_queues() 142 q = scctx->isc_vectors - 1; in iavf_map_queues() 145 (scctx->isc_vectors * sizeof(struct virtchnl_vector_map)); in iavf_map_queues() 152 vm->num_vectors = scctx->isc_vectors; in iavf_map_queues()
|
| H A D | if_iavf_iflib.c | 260 if_softc_ctx_t scctx; in iavf_if_attach_pre() local 278 vsi->shared = scctx = iflib_get_softc_ctx(ctx); in iavf_if_attach_pre() 360 scctx->isc_ntxqsets_max = scctx->isc_nrxqsets_max = in iavf_if_attach_pre() 363 scctx->isc_txqsizes[0] = roundup2(scctx->isc_ntxd[0] in iavf_if_attach_pre() 365 scctx->isc_txrx = &iavf_txrx_hwb; in iavf_if_attach_pre() 367 scctx->isc_txqsizes[0] = roundup2(scctx->isc_ntxd[0] in iavf_if_attach_pre() 369 scctx->isc_txrx = &iavf_txrx_dwb; in iavf_if_attach_pre() 371 scctx->isc_rxqsizes[0] = roundup2(scctx->isc_nrxd[0] in iavf_if_attach_pre() 373 scctx->isc_msix_bar = pci_msix_table_bar(dev); in iavf_if_attach_pre() 374 scctx->isc_tx_nsegments = IAVF_MAX_TX_SEGS; in iavf_if_attach_pre() [all …]
|
| H A D | iavf_txrx_iflib.c | 261 if_softc_ctx_t scctx; in iavf_tso_setup() local 271 scctx = txr->que->vsi->shared; in iavf_tso_setup() 304 return ((idx + 1) & (scctx->isc_ntxd[0]-1)); in iavf_tso_setup() 323 if_softc_ctx_t scctx = vsi->shared; in iavf_isc_txd_encap() local 357 mask = scctx->isc_ntxd[0] - 1; in iavf_isc_txd_encap() 451 if_softc_ctx_t scctx = que->vsi->shared; in iavf_get_tx_head() local 453 void *head = &txr->tx_base[scctx->isc_ntxd[0]]; in iavf_get_tx_head() 477 if_softc_ctx_t scctx = vsi->shared; in iavf_isc_txd_credits_update_hwb() local 487 credits += scctx->isc_ntxd[0]; in iavf_isc_txd_credits_update_hwb() 514 if_softc_ctx_t scctx = vsi->shared; in iavf_isc_txd_credits_update_dwb() local [all …]
|
| /src/sys/dev/mgb/ |
| H A D | if_mgb.c | 335 if_softc_ctx_t scctx; in mgb_attach_pre() local 343 scctx = iflib_get_softc_ctx(ctx); in mgb_attach_pre() 346 scctx->isc_txrx = &mgb_txrx; in mgb_attach_pre() 347 scctx->isc_tx_nsegments = MGB_DMA_MAXSEGS; in mgb_attach_pre() 349 scctx->isc_txqsizes[0] = sizeof(struct mgb_ring_desc) * in mgb_attach_pre() 350 scctx->isc_ntxd[0]; in mgb_attach_pre() 351 scctx->isc_rxqsizes[0] = sizeof(struct mgb_ring_desc) * in mgb_attach_pre() 352 scctx->isc_nrxd[0]; in mgb_attach_pre() 355 scctx->isc_txqsizes[1] = sizeof(uint32_t) * scctx->isc_ntxd[1]; in mgb_attach_pre() 356 scctx->isc_rxqsizes[1] = sizeof(uint32_t) * scctx->isc_nrxd[1]; in mgb_attach_pre() [all …]
|
| /src/sys/dev/axgbe/ |
| H A D | if_axgbe_pci.c | 397 if_softc_ctx_t scctx; in axgbe_if_attach_pre() local 408 sc->scctx = scctx = iflib_get_softc_ctx(ctx); in axgbe_if_attach_pre() 667 if_softc_ctx_t scctx = sc->scctx; in axgbe_init_iflib_softc_ctx() local 671 scctx->isc_nrxqsets = pdata->rx_q_count; in axgbe_init_iflib_softc_ctx() 672 scctx->isc_ntxqsets = pdata->tx_q_count; in axgbe_init_iflib_softc_ctx() 673 scctx->isc_msix_bar = pci_msix_table_bar(pdata->dev); in axgbe_init_iflib_softc_ctx() 674 scctx->isc_tx_nsegments = 32; in axgbe_init_iflib_softc_ctx() 677 scctx->isc_txqsizes[i] = in axgbe_init_iflib_softc_ctx() 678 roundup2(scctx->isc_ntxd[i] * sizeof(struct xgbe_ring_desc), in axgbe_init_iflib_softc_ctx() 680 scctx->isc_txd_size[i] = sizeof(struct xgbe_ring_desc); in axgbe_init_iflib_softc_ctx() [all …]
|
| /src/sys/net/ |
| H A D | iflib.c | 696 static void _iflib_pre_assert(if_softc_ctx_t scctx); 723 if_softc_ctx_t scctx = &ctx->ifc_softc_ctx; in iflib_num_rx_descs() local 727 return (scctx->isc_nrxd[first_rxq]); in iflib_num_rx_descs() 733 if_softc_ctx_t scctx = &ctx->ifc_softc_ctx; in iflib_num_tx_descs() local 737 return (scctx->isc_ntxd[first_txq]); in iflib_num_tx_descs() 1159 if_softc_ctx_t scctx = &ctx->ifc_softc_ctx; in iflib_netmap_rxsync() local 1242 while (*cidxp >= scctx->isc_nrxd[0]) in iflib_netmap_rxsync() 1243 *cidxp -= scctx->isc_nrxd[0]; in iflib_netmap_rxsync() 1687 if_softc_ctx_t scctx = &ctx->ifc_softc_ctx; in iflib_txsd_alloc() local 1694 nsegments = scctx->isc_tx_nsegments; in iflib_txsd_alloc() [all …]
|
| /src/sys/dev/igc/ |
| H A D | igc_txrx.c | 81 if_softc_ctx_t scctx = sc->shared; in igc_dump_rs() local 89 ntxd = scctx->isc_ntxd[0]; in igc_dump_rs() 268 if_softc_ctx_t scctx = sc->shared; in igc_isc_txd_encap() local 287 ntxd = scctx->isc_ntxd[0]; in igc_isc_txd_encap() 291 if (i == scctx->isc_ntxd[0]) in igc_isc_txd_encap() 307 if (++i == scctx->isc_ntxd[0]) { in igc_isc_txd_encap() 341 if_softc_ctx_t scctx = sc->shared; in igc_isc_txd_credits_update() local 367 ntxd = scctx->isc_ntxd[0]; in igc_isc_txd_credits_update() 394 if_softc_ctx_t scctx = sc->shared; in igc_isc_rxd_refill() local 412 if (++next_pidx == scctx->isc_nrxd[0]) in igc_isc_rxd_refill() [all …]
|
| H A D | if_igc.c | 395 if_softc_ctx_t scctx = sc->shared; in igc_get_regs() local 398 int ntxd = scctx->isc_ntxd[0]; in igc_get_regs() 399 int nrxd = scctx->isc_nrxd[0]; in igc_get_regs() 463 if_softc_ctx_t scctx; in igc_if_attach_pre() local 474 scctx = sc->shared = iflib_get_softc_ctx(ctx); in igc_if_attach_pre() 549 scctx->isc_tx_nsegments = IGC_MAX_SCATTER; in igc_if_attach_pre() 550 scctx->isc_nrxqsets_max = in igc_if_attach_pre() 551 scctx->isc_ntxqsets_max = igc_set_num_queues(ctx); in igc_if_attach_pre() 554 scctx->isc_ntxqsets_max); in igc_if_attach_pre() 556 scctx->isc_txqsizes[0] = roundup2(scctx->isc_ntxd[0] * in igc_if_attach_pre() [all …]
|
| /src/sys/dev/ice/ |
| H A D | if_ice_iflib.c | 389 if_softc_ctx_t scctx = sc->scctx; in ice_setup_scctx() local 402 scctx->isc_ntxqsets = scctx->isc_nrxqsets = 1; in ice_setup_scctx() 403 scctx->isc_ntxqsets_max = 1; in ice_setup_scctx() 404 scctx->isc_nrxqsets_max = 1; in ice_setup_scctx() 412 sc->ifc_sysctl_ntxqs = scctx->isc_ntxqsets; in ice_setup_scctx() 413 sc->ifc_sysctl_nrxqs = scctx->isc_nrxqsets; in ice_setup_scctx() 415 if (scctx->isc_ntxqsets == 0) in ice_setup_scctx() 416 scctx->isc_ntxqsets = hw->func_caps.common_cap.rss_table_size; in ice_setup_scctx() 417 if (scctx->isc_nrxqsets == 0) in ice_setup_scctx() 418 scctx->isc_nrxqsets = hw->func_caps.common_cap.rss_table_size; in ice_setup_scctx() [all …]
|
| /src/sys/dev/ixl/ |
| H A D | ixl_txrx.c | 282 if_softc_ctx_t scctx; in ixl_tso_setup() local 292 scctx = txr->que->vsi->shared; in ixl_tso_setup() 325 return ((idx + 1) & (scctx->isc_ntxd[0]-1)); in ixl_tso_setup() 341 if_softc_ctx_t scctx = vsi->shared; in ixl_isc_txd_encap() local 370 mask = scctx->isc_ntxd[0] - 1; in ixl_isc_txd_encap() 454 if_softc_ctx_t scctx = que->vsi->shared; in ixl_get_tx_head() local 456 void *head = &txr->tx_base[scctx->isc_ntxd[0]]; in ixl_get_tx_head() 465 if_softc_ctx_t scctx = vsi->shared; in ixl_isc_txd_credits_update_hwb() local 475 credits += scctx->isc_ntxd[0]; in ixl_isc_txd_credits_update_hwb() 487 if_softc_ctx_t scctx = vsi->shared; in ixl_isc_txd_credits_update_dwb() local [all …]
|
| H A D | if_ixl.c | 407 if_softc_ctx_t scctx = pf->vsi.shared; in ixl_setup_ssctx() local 411 scctx->isc_ntxqsets_max = scctx->isc_nrxqsets_max = 1; in ixl_setup_ssctx() 412 scctx->isc_ntxqsets = scctx->isc_nrxqsets = 1; in ixl_setup_ssctx() 414 scctx->isc_ntxqsets_max = scctx->isc_nrxqsets_max = 128; in ixl_setup_ssctx() 416 scctx->isc_ntxqsets_max = scctx->isc_nrxqsets_max = 64; in ixl_setup_ssctx() 419 scctx->isc_txqsizes[0] = roundup2(scctx->isc_ntxd[0] in ixl_setup_ssctx() 421 scctx->isc_txrx = &ixl_txrx_hwb; in ixl_setup_ssctx() 423 scctx->isc_txqsizes[0] = roundup2(scctx->isc_ntxd[0] in ixl_setup_ssctx() 425 scctx->isc_txrx = &ixl_txrx_dwb; in ixl_setup_ssctx() 428 scctx->isc_txrx->ift_legacy_intr = ixl_intr; in ixl_setup_ssctx() [all …]
|
| H A D | ixl_pf_iflib.c | 439 if_softc_ctx_t scctx = iflib_get_softc_ctx(vsi->ctx); in ixl_initialize_vsi() local 525 tctx.qlen = scctx->isc_ntxd[0]; in ixl_initialize_vsi() 540 (scctx->isc_ntxd[0] * sizeof(struct i40e_tx_desc)); in ixl_initialize_vsi() 580 rctx.rxmax = (scctx->isc_max_frame_size < max_rxmax) ? in ixl_initialize_vsi() 581 scctx->isc_max_frame_size : max_rxmax; in ixl_initialize_vsi() 586 rctx.qlen = scctx->isc_nrxd[0]; in ixl_initialize_vsi()
|
| /src/sys/dev/aq/ |
| H A D | aq_main.c | 328 if_softc_ctx_t scctx; in aq_if_attach_pre() local 338 softc->scctx = iflib_get_softc_ctx(ctx); in aq_if_attach_pre() 340 scctx = softc->scctx; in aq_if_attach_pre() 389 scctx->isc_tx_csum_flags = CSUM_IP | CSUM_TCP | CSUM_UDP | CSUM_TSO; in aq_if_attach_pre() 391 scctx->isc_capabilities = IFCAP_RXCSUM | IFCAP_TXCSUM | IFCAP_HWCSUM | in aq_if_attach_pre() 394 scctx->isc_capenable = scctx->isc_capabilities; in aq_if_attach_pre() 402 scctx->isc_tx_nsegments = 31, in aq_if_attach_pre() 403 scctx->isc_tx_tso_segments_max = 31; in aq_if_attach_pre() 404 scctx->isc_tx_tso_size_max = in aq_if_attach_pre() 406 scctx->isc_tx_tso_segsize_max = HW_ATL_B0_MTU_JUMBO; in aq_if_attach_pre() [all …]
|
| H A D | aq_device.h | 101 if_softc_ctx_t scctx; member
|
| /src/sys/dev/ixgbe/ |
| H A D | if_ixv.c | 251 if_softc_ctx_t scctx = sc->shared; in ixv_if_tx_queues_alloc() local 276 scctx->isc_ntxd[0], M_DEVBUF, M_NOWAIT | M_ZERO))) { in ixv_if_tx_queues_alloc() 280 for (j = 0; j < scctx->isc_ntxd[0]; j++) in ixv_if_tx_queues_alloc() 397 if_softc_ctx_t scctx; in ixv_if_attach_pre() local 409 scctx = sc->shared = iflib_get_softc_ctx(ctx); in ixv_if_attach_pre() 490 scctx->isc_ntxqsets_max = scctx->isc_nrxqsets_max = 2; in ixv_if_attach_pre() 493 scctx->isc_ntxqsets_max = scctx->isc_nrxqsets_max = 1; in ixv_if_attach_pre() 495 scctx->isc_txqsizes[0] = in ixv_if_attach_pre() 496 roundup2(scctx->isc_ntxd[0] * sizeof(union ixgbe_adv_tx_desc) + in ixv_if_attach_pre() 498 scctx->isc_rxqsizes[0] = in ixv_if_attach_pre() [all …]
|
| H A D | ix_txrx.c | 176 if_softc_ctx_t scctx = sc->shared; in ixgbe_isc_txd_encap() local 195 ntxd = scctx->isc_ntxd[0]; in ixgbe_isc_txd_encap() 211 if (++i == scctx->isc_ntxd[0]) in ixgbe_isc_txd_encap() 231 if (++i == scctx->isc_ntxd[0]) { in ixgbe_isc_txd_encap() 270 if_softc_ctx_t scctx = sc->shared; in ixgbe_isc_txd_credits_update() local 296 ntxd = scctx->isc_ntxd[0]; in ixgbe_isc_txd_credits_update() 400 if_softc_ctx_t scctx = sc->shared; in ixgbe_isc_rxd_pkt_get() local 453 if ((scctx->isc_capenable & IFCAP_RXCSUM) != 0) in ixgbe_isc_rxd_pkt_get()
|
| H A D | if_ix.c | 485 if_softc_ctx_t scctx = sc->shared; in ixgbe_if_tx_queues_alloc() local 513 scctx->isc_ntxd[0], M_IXGBE, M_NOWAIT | M_ZERO); in ixgbe_if_tx_queues_alloc() 518 for (j = 0; j < scctx->isc_ntxd[0]; j++) in ixgbe_if_tx_queues_alloc() 744 if_softc_ctx_t scctx = sc->shared; in ixgbe_initialize_receive_units() local 790 scctx->isc_nrxd[0] * sizeof(union ixgbe_adv_rx_desc)); in ixgbe_initialize_receive_units() 858 if_softc_ctx_t scctx = sc->shared; in ixgbe_initialize_transmit_units() local 874 scctx->isc_ntxd[0] * sizeof(union ixgbe_adv_tx_desc)); in ixgbe_initialize_transmit_units() 884 txr->tx_cidx_processed = scctx->isc_ntxd[0] - 1; in ixgbe_initialize_transmit_units() 885 for (int k = 0; k < scctx->isc_ntxd[0]; k++) in ixgbe_initialize_transmit_units() 983 if_softc_ctx_t scctx; in ixgbe_if_attach_pre() local [all …]
|
| /src/sys/dev/bnxt/bnxt_en/ |
| H A D | if_bnxt.c | 502 (softc->scctx->isc_nrxqsets * 2) + 1 + i; in bnxt_tx_queues_alloc() 506 softc->scctx->isc_ntxd[0]; in bnxt_tx_queues_alloc() 518 (softc->scctx->isc_nrxqsets * 2) + 1 + i; in bnxt_tx_queues_alloc() 521 softc->tx_rings[i].ring_size = softc->scctx->isc_ntxd[1]; in bnxt_tx_queues_alloc() 538 softc->nq_rings[i].ring.ring_size = softc->scctx->isc_ntxd[2]; in bnxt_tx_queues_alloc() 703 softc->scctx->isc_nrxd[0]; in bnxt_rx_queues_alloc() 717 softc->rx_rings[i].ring_size = softc->scctx->isc_nrxd[1]; in bnxt_rx_queues_alloc() 740 softc->ag_rings[i].ring_size = softc->scctx->isc_nrxd[2]; in bnxt_rx_queues_alloc() 2302 if_softc_ctx_t scctx; in bnxt_attach_pre() local 2308 softc->scctx = iflib_get_softc_ctx(ctx); in bnxt_attach_pre() [all …]
|
| /src/sys/dev/enetc/ |
| H A D | if_enetc.c | 365 if_softc_ctx_t scctx; in enetc_attach_pre() local 370 scctx = iflib_get_softc_ctx(ctx); in enetc_attach_pre() 373 sc->shared = scctx; in enetc_attach_pre() 400 scctx->isc_txrx = &enetc_txrx; in enetc_attach_pre() 401 scctx->isc_tx_nsegments = ENETC_MAX_SCATTER; in enetc_attach_pre() 402 enetc_max_nqueues(sc, &scctx->isc_nrxqsets_max, &scctx->isc_ntxqsets_max); in enetc_attach_pre() 404 if (scctx->isc_ntxd[0] % ENETC_DESC_ALIGN != 0) { in enetc_attach_pre() 411 if (scctx->isc_nrxd[0] % ENETC_DESC_ALIGN != 0) { in enetc_attach_pre() 418 scctx->isc_txqsizes[0] = scctx->isc_ntxd[0] * sizeof(union enetc_tx_bd); in enetc_attach_pre() 419 scctx->isc_rxqsizes[0] = scctx->isc_nrxd[0] * sizeof(union enetc_rx_bd); in enetc_attach_pre() [all …]
|