Lines Matching refs:q_vector
909 i40e_force_wb(vsi, tx_ring->q_vector); in i40e_detect_recover_hung()
1063 struct i40e_q_vector *q_vector) in i40e_enable_wb_on_itr() argument
1065 u16 flags = q_vector->tx.ring[0].flags; in i40e_enable_wb_on_itr()
1071 if (q_vector->arm_wb_state) in i40e_enable_wb_on_itr()
1079 I40E_PFINT_DYN_CTLN(q_vector->reg_idx), in i40e_enable_wb_on_itr()
1087 q_vector->arm_wb_state = true; in i40e_enable_wb_on_itr()
1096 void i40e_force_wb(struct i40e_vsi *vsi, struct i40e_q_vector *q_vector) in i40e_force_wb() argument
1106 I40E_PFINT_DYN_CTLN(q_vector->reg_idx), val); in i40e_force_wb()
1118 static inline bool i40e_container_is_rx(struct i40e_q_vector *q_vector, in i40e_container_is_rx() argument
1121 return &q_vector->rx == rc; in i40e_container_is_rx()
1124 static inline unsigned int i40e_itr_divisor(struct i40e_q_vector *q_vector) in i40e_itr_divisor() argument
1128 switch (q_vector->vsi->back->hw.phy.link_info.link_speed) { in i40e_itr_divisor()
1162 static void i40e_update_itr(struct i40e_q_vector *q_vector, in i40e_update_itr() argument
1177 itr = i40e_container_is_rx(q_vector, rc) ? in i40e_update_itr()
1195 if (q_vector->itr_countdown) { in i40e_update_itr()
1203 if (i40e_container_is_rx(q_vector, rc)) { in i40e_update_itr()
1210 (q_vector->tx.target_itr & I40E_ITR_ADAPTIVE_LATENCY)) { in i40e_update_itr()
1221 (q_vector->rx.target_itr & I40E_ITR_MASK) == in i40e_update_itr()
1249 itr = min(q_vector->tx.current_itr, q_vector->rx.current_itr); in i40e_update_itr()
1336 itr += DIV_ROUND_UP(avg_wire_size, i40e_itr_divisor(q_vector)) * in i40e_update_itr()
1604 rx_ring->queue_index, rx_ring->q_vector->napi.napi_id); in i40e_setup_rx_descriptors()
2139 skb = __napi_alloc_skb(&rx_ring->q_vector->napi, in i40e_construct_skb()
2389 rx_ring->q_vector->rx.total_packets += total_rx_packets; in i40e_update_rx_stats()
2390 rx_ring->q_vector->rx.total_bytes += total_rx_bytes; in i40e_update_rx_stats()
2561 napi_gro_receive(&rx_ring->q_vector->napi, skb); in i40e_clean_rx_irq()
2624 struct i40e_q_vector *q_vector) in i40e_update_enable_itr() argument
2636 i40e_update_itr(q_vector, &q_vector->tx); in i40e_update_enable_itr()
2637 i40e_update_itr(q_vector, &q_vector->rx); in i40e_update_enable_itr()
2647 if (q_vector->rx.target_itr < q_vector->rx.current_itr) { in i40e_update_enable_itr()
2650 q_vector->rx.target_itr); in i40e_update_enable_itr()
2651 q_vector->rx.current_itr = q_vector->rx.target_itr; in i40e_update_enable_itr()
2652 q_vector->itr_countdown = ITR_COUNTDOWN_START; in i40e_update_enable_itr()
2653 } else if ((q_vector->tx.target_itr < q_vector->tx.current_itr) || in i40e_update_enable_itr()
2654 ((q_vector->rx.target_itr - q_vector->rx.current_itr) < in i40e_update_enable_itr()
2655 (q_vector->tx.target_itr - q_vector->tx.current_itr))) { in i40e_update_enable_itr()
2660 q_vector->tx.target_itr); in i40e_update_enable_itr()
2661 q_vector->tx.current_itr = q_vector->tx.target_itr; in i40e_update_enable_itr()
2662 q_vector->itr_countdown = ITR_COUNTDOWN_START; in i40e_update_enable_itr()
2663 } else if (q_vector->rx.current_itr != q_vector->rx.target_itr) { in i40e_update_enable_itr()
2666 q_vector->rx.target_itr); in i40e_update_enable_itr()
2667 q_vector->rx.current_itr = q_vector->rx.target_itr; in i40e_update_enable_itr()
2668 q_vector->itr_countdown = ITR_COUNTDOWN_START; in i40e_update_enable_itr()
2672 if (q_vector->itr_countdown) in i40e_update_enable_itr()
2673 q_vector->itr_countdown--; in i40e_update_enable_itr()
2677 wr32(hw, INTREG(q_vector->reg_idx), intval); in i40e_update_enable_itr()
2691 struct i40e_q_vector *q_vector = in i40e_napi_poll() local
2693 struct i40e_vsi *vsi = q_vector->vsi; in i40e_napi_poll()
2708 i40e_for_each_ring(ring, q_vector->tx) { in i40e_napi_poll()
2726 if (unlikely(q_vector->num_ringpairs > 1)) in i40e_napi_poll()
2731 budget_per_ring = max_t(int, budget / q_vector->num_ringpairs, 1); in i40e_napi_poll()
2736 i40e_for_each_ring(ring, q_vector->rx) { in i40e_napi_poll()
2758 if (!cpumask_test_cpu(cpu_id, &q_vector->affinity_mask)) { in i40e_napi_poll()
2763 i40e_force_wb(vsi, q_vector); in i40e_napi_poll()
2770 q_vector->tx.ring[0].tx_stats.tx_force_wb++; in i40e_napi_poll()
2771 i40e_enable_wb_on_itr(vsi, q_vector); in i40e_napi_poll()
2777 q_vector->arm_wb_state = false; in i40e_napi_poll()
2783 i40e_update_enable_itr(vsi, q_vector); in i40e_napi_poll()