Lines Matching refs:q_vector
1113 static bool ixgbe_clean_tx_irq(struct ixgbe_q_vector *q_vector, in ixgbe_clean_tx_irq() argument
1116 struct ixgbe_adapter *adapter = q_vector->adapter; in ixgbe_clean_tx_irq()
1120 unsigned int budget = q_vector->tx.work_limit; in ixgbe_clean_tx_irq()
1212 q_vector->tx.total_bytes += total_bytes; in ixgbe_clean_tx_irq()
1213 q_vector->tx.total_packets += total_packets; in ixgbe_clean_tx_irq()
1344 static void ixgbe_update_dca(struct ixgbe_q_vector *q_vector) in ixgbe_update_dca() argument
1346 struct ixgbe_adapter *adapter = q_vector->adapter; in ixgbe_update_dca()
1350 if (q_vector->cpu == cpu) in ixgbe_update_dca()
1353 ixgbe_for_each_ring(ring, q_vector->tx) in ixgbe_update_dca()
1356 ixgbe_for_each_ring(ring, q_vector->rx) in ixgbe_update_dca()
1359 q_vector->cpu = cpu; in ixgbe_update_dca()
1377 adapter->q_vector[i]->cpu = -1; in ixgbe_setup_dca()
1378 ixgbe_update_dca(adapter->q_vector[i]); in ixgbe_setup_dca()
1687 u32 flags = rx_ring->q_vector->adapter->flags; in ixgbe_process_skb_fields()
1717 void ixgbe_rx_skb(struct ixgbe_q_vector *q_vector, in ixgbe_rx_skb() argument
1720 napi_gro_receive(&q_vector->napi, skb); in ixgbe_rx_skb()
2125 skb = napi_alloc_skb(&rx_ring->q_vector->napi, IXGBE_RX_HDR_SIZE); in ixgbe_construct_skb()
2293 static int ixgbe_clean_rx_irq(struct ixgbe_q_vector *q_vector, in ixgbe_clean_rx_irq() argument
2298 struct ixgbe_adapter *adapter = q_vector->adapter; in ixgbe_clean_rx_irq()
2425 ixgbe_rx_skb(q_vector, skb); in ixgbe_clean_rx_irq()
2444 q_vector->rx.total_packets += total_rx_packets; in ixgbe_clean_rx_irq()
2445 q_vector->rx.total_bytes += total_rx_bytes; in ixgbe_clean_rx_irq()
2459 struct ixgbe_q_vector *q_vector; in ixgbe_configure_msix() local
2475 q_vector = adapter->q_vector[v_idx]; in ixgbe_configure_msix()
2477 ixgbe_for_each_ring(ring, q_vector->rx) in ixgbe_configure_msix()
2480 ixgbe_for_each_ring(ring, q_vector->tx) in ixgbe_configure_msix()
2483 ixgbe_write_eitr(q_vector); in ixgbe_configure_msix()
2525 static void ixgbe_update_itr(struct ixgbe_q_vector *q_vector, in ixgbe_update_itr() argument
2558 itr = (q_vector->itr >> 2) + IXGBE_ITR_ADAPTIVE_MIN_INC; in ixgbe_update_itr()
2581 itr = (q_vector->itr >> 2) + IXGBE_ITR_ADAPTIVE_MIN_INC; in ixgbe_update_itr()
2591 itr = q_vector->itr >> 2; in ixgbe_update_itr()
2600 itr = q_vector->itr >> 3; in ixgbe_update_itr()
2670 switch (q_vector->adapter->link_speed) { in ixgbe_update_itr()
2708 void ixgbe_write_eitr(struct ixgbe_q_vector *q_vector) in ixgbe_write_eitr() argument
2710 struct ixgbe_adapter *adapter = q_vector->adapter; in ixgbe_write_eitr()
2712 int v_idx = q_vector->v_idx; in ixgbe_write_eitr()
2713 u32 itr_reg = q_vector->itr & IXGBE_MAX_EITR; in ixgbe_write_eitr()
2737 static void ixgbe_set_itr(struct ixgbe_q_vector *q_vector) in ixgbe_set_itr() argument
2741 ixgbe_update_itr(q_vector, &q_vector->tx); in ixgbe_set_itr()
2742 ixgbe_update_itr(q_vector, &q_vector->rx); in ixgbe_set_itr()
2745 new_itr = min(q_vector->rx.itr, q_vector->tx.itr); in ixgbe_set_itr()
2751 if (new_itr != q_vector->itr) { in ixgbe_set_itr()
2753 q_vector->itr = new_itr; in ixgbe_set_itr()
2755 ixgbe_write_eitr(q_vector); in ixgbe_set_itr()
3131 struct ixgbe_q_vector *q_vector = data; in ixgbe_msix_clean_rings() local
3135 if (q_vector->rx.ring || q_vector->tx.ring) in ixgbe_msix_clean_rings()
3136 napi_schedule_irqoff(&q_vector->napi); in ixgbe_msix_clean_rings()
3150 struct ixgbe_q_vector *q_vector = in ixgbe_poll() local
3152 struct ixgbe_adapter *adapter = q_vector->adapter; in ixgbe_poll()
3159 ixgbe_update_dca(q_vector); in ixgbe_poll()
3162 ixgbe_for_each_ring(ring, q_vector->tx) { in ixgbe_poll()
3164 ixgbe_clean_xdp_tx_irq(q_vector, ring, budget) : in ixgbe_poll()
3165 ixgbe_clean_tx_irq(q_vector, ring, budget); in ixgbe_poll()
3177 if (q_vector->rx.count > 1) in ixgbe_poll()
3178 per_ring_budget = max(budget/q_vector->rx.count, 1); in ixgbe_poll()
3182 ixgbe_for_each_ring(ring, q_vector->rx) { in ixgbe_poll()
3184 ixgbe_clean_rx_irq_zc(q_vector, ring, in ixgbe_poll()
3186 ixgbe_clean_rx_irq(q_vector, ring, in ixgbe_poll()
3201 ixgbe_set_itr(q_vector); in ixgbe_poll()
3204 BIT_ULL(q_vector->v_idx)); in ixgbe_poll()
3224 struct ixgbe_q_vector *q_vector = adapter->q_vector[vector]; in ixgbe_request_msix_irqs() local
3227 if (q_vector->tx.ring && q_vector->rx.ring) { in ixgbe_request_msix_irqs()
3228 snprintf(q_vector->name, sizeof(q_vector->name), in ixgbe_request_msix_irqs()
3231 } else if (q_vector->rx.ring) { in ixgbe_request_msix_irqs()
3232 snprintf(q_vector->name, sizeof(q_vector->name), in ixgbe_request_msix_irqs()
3234 } else if (q_vector->tx.ring) { in ixgbe_request_msix_irqs()
3235 snprintf(q_vector->name, sizeof(q_vector->name), in ixgbe_request_msix_irqs()
3242 q_vector->name, q_vector); in ixgbe_request_msix_irqs()
3252 &q_vector->affinity_mask); in ixgbe_request_msix_irqs()
3271 adapter->q_vector[vector]); in ixgbe_request_msix_irqs()
3289 struct ixgbe_q_vector *q_vector = adapter->q_vector[0]; in ixgbe_intr() local
3342 napi_schedule_irqoff(&q_vector->napi); in ixgbe_intr()
3394 struct ixgbe_q_vector *q_vector = adapter->q_vector[vector]; in ixgbe_free_irq() local
3398 if (!q_vector->rx.ring && !q_vector->tx.ring) in ixgbe_free_irq()
3404 free_irq(entry->vector, q_vector); in ixgbe_free_irq()
3452 struct ixgbe_q_vector *q_vector = adapter->q_vector[0]; in ixgbe_configure_msi_and_legacy() local
3454 ixgbe_write_eitr(q_vector); in ixgbe_configure_msi_and_legacy()
3505 if (!ring->q_vector || (ring->q_vector->itr < IXGBE_100K_ITR)) in ixgbe_configure_tx_ring()
3528 struct ixgbe_q_vector *q_vector = ring->q_vector; in ixgbe_configure_tx_ring() local
3530 if (q_vector) in ixgbe_configure_tx_ring()
3532 &q_vector->affinity_mask, in ixgbe_configure_tx_ring()
4992 napi_enable(&adapter->q_vector[q_idx]->napi); in ixgbe_napi_enable_all()
5000 napi_disable(&adapter->q_vector[q_idx]->napi); in ixgbe_napi_disable_all()
6516 if (tx_ring->q_vector) in ixgbe_setup_tx_resources()
6517 ring_node = tx_ring->q_vector->numa_node; in ixgbe_setup_tx_resources()
6595 struct ixgbe_q_vector *q_vector = rx_ring->q_vector; in ixgbe_rx_napi_id() local
6597 return q_vector ? q_vector->napi.napi_id : 0; in ixgbe_rx_napi_id()
6617 if (rx_ring->q_vector) in ixgbe_setup_rx_resources()
6618 ring_node = rx_ring->q_vector->numa_node; in ixgbe_setup_rx_resources()
7426 struct ixgbe_q_vector *qv = adapter->q_vector[i]; in ixgbe_check_hang_subtask()
8452 struct ixgbe_q_vector *q_vector = ring->q_vector; in ixgbe_atr() local
8467 if (!q_vector) in ixgbe_atr()
8489 struct ixgbe_adapter *adapter = q_vector->adapter; in ixgbe_atr()
8592 ixgbe_fdir_add_signature_filter_82599(&q_vector->adapter->hw, in ixgbe_atr()
10195 struct ixgbe_q_vector *qv = ring->q_vector; in ixgbe_fwd_del()
10567 napi_disable(&rx_ring->q_vector->napi); in ixgbe_txrx_ring_disable()
10597 napi_enable(&rx_ring->q_vector->napi); in ixgbe_txrx_ring_enable()