Lines Matching refs:rxo
616 struct be_rx_obj *rxo, u32 erx_stat) in populate_erx_stats() argument
619 rx_stats(rxo)->rx_drops_no_frags = erx_stat; in populate_erx_stats()
624 accumulate_16bit_val(&rx_stats(rxo)->rx_drops_no_frags, in populate_erx_stats()
631 struct be_rx_obj *rxo; in be_parse_stats() local
647 for_all_rx_queues(adapter, rxo, i) { in be_parse_stats()
648 erx_stat = erx->rx_drops_no_fragments[rxo->q.id]; in be_parse_stats()
649 populate_erx_stats(adapter, rxo, erx_stat); in be_parse_stats()
659 struct be_rx_obj *rxo; in be_get_stats64() local
665 for_all_rx_queues(adapter, rxo, i) { in be_get_stats64()
666 const struct be_rx_stats *rx_stats = rx_stats(rxo); in be_get_stats64()
670 pkts = rx_stats(rxo)->rx_pkts; in be_get_stats64()
671 bytes = rx_stats(rxo)->rx_bytes; in be_get_stats64()
675 stats->multicast += rx_stats(rxo)->rx_mcast_pkts; in be_get_stats64()
676 stats->rx_dropped += rx_stats(rxo)->rx_drops_no_skbs + in be_get_stats64()
677 rx_stats(rxo)->rx_drops_no_frags; in be_get_stats64()
2142 struct be_rx_obj *rxo; in be_get_new_eqd() local
2157 for_all_rx_queues_on_eq(adapter, eqo, rxo, i) { in be_get_new_eqd()
2159 start = u64_stats_fetch_begin_irq(&rxo->stats.sync); in be_get_new_eqd()
2160 rx_pkts += rxo->stats.rx_pkts; in be_get_new_eqd()
2161 } while (u64_stats_fetch_retry_irq(&rxo->stats.sync, start)); in be_get_new_eqd()
2251 static void be_rx_stats_update(struct be_rx_obj *rxo, in be_rx_stats_update() argument
2254 struct be_rx_stats *stats = rx_stats(rxo); in be_rx_stats_update()
2278 static struct be_rx_page_info *get_rx_page_info(struct be_rx_obj *rxo) in get_rx_page_info() argument
2280 struct be_adapter *adapter = rxo->adapter; in get_rx_page_info()
2282 struct be_queue_info *rxq = &rxo->q; in get_rx_page_info()
2285 rx_page_info = &rxo->page_info_tbl[frag_idx]; in get_rx_page_info()
2305 static void be_rx_compl_discard(struct be_rx_obj *rxo, in be_rx_compl_discard() argument
2312 page_info = get_rx_page_info(rxo); in be_rx_compl_discard()
2322 static void skb_fill_rx_data(struct be_rx_obj *rxo, struct sk_buff *skb, in skb_fill_rx_data() argument
2330 page_info = get_rx_page_info(rxo); in skb_fill_rx_data()
2367 page_info = get_rx_page_info(rxo); in skb_fill_rx_data()
2394 static void be_rx_compl_process(struct be_rx_obj *rxo, struct napi_struct *napi, in be_rx_compl_process() argument
2397 struct be_adapter *adapter = rxo->adapter; in be_rx_compl_process()
2403 rx_stats(rxo)->rx_drops_no_skbs++; in be_rx_compl_process()
2404 be_rx_compl_discard(rxo, rxcp); in be_rx_compl_process()
2408 skb_fill_rx_data(rxo, skb, rxcp); in be_rx_compl_process()
2416 skb_record_rx_queue(skb, rxo - &adapter->rx_obj[0]); in be_rx_compl_process()
2430 static void be_rx_compl_process_gro(struct be_rx_obj *rxo, in be_rx_compl_process_gro() argument
2434 struct be_adapter *adapter = rxo->adapter; in be_rx_compl_process_gro()
2442 be_rx_compl_discard(rxo, rxcp); in be_rx_compl_process_gro()
2448 page_info = get_rx_page_info(rxo); in be_rx_compl_process_gro()
2474 skb_record_rx_queue(skb, rxo - &adapter->rx_obj[0]); in be_rx_compl_process_gro()
2531 static struct be_rx_compl_info *be_rx_compl_get(struct be_rx_obj *rxo) in be_rx_compl_get() argument
2533 struct be_eth_rx_compl *compl = queue_tail_node(&rxo->cq); in be_rx_compl_get()
2534 struct be_rx_compl_info *rxcp = &rxo->rxcp; in be_rx_compl_get()
2535 struct be_adapter *adapter = rxo->adapter; in be_rx_compl_get()
2572 queue_tail_inc(&rxo->cq); in be_rx_compl_get()
2589 static void be_post_rx_frags(struct be_rx_obj *rxo, gfp_t gfp, u32 frags_needed) in be_post_rx_frags() argument
2591 struct be_adapter *adapter = rxo->adapter; in be_post_rx_frags()
2593 struct be_queue_info *rxq = &rxo->q; in be_post_rx_frags()
2600 page_info = &rxo->page_info_tbl[rxq->head]; in be_post_rx_frags()
2605 rx_stats(rxo)->rx_post_fail++; in be_post_rx_frags()
2642 page_info = &rxo->page_info_tbl[rxq->head]; in be_post_rx_frags()
2655 if (rxo->rx_post_starved) in be_post_rx_frags()
2656 rxo->rx_post_starved = false; in be_post_rx_frags()
2664 rxo->rx_post_starved = true; in be_post_rx_frags()
2812 static void be_rxq_clean(struct be_rx_obj *rxo) in be_rxq_clean() argument
2814 struct be_queue_info *rxq = &rxo->q; in be_rxq_clean()
2818 page_info = get_rx_page_info(rxo); in be_rxq_clean()
2827 static void be_rx_cq_clean(struct be_rx_obj *rxo) in be_rx_cq_clean() argument
2829 struct be_queue_info *rx_cq = &rxo->cq; in be_rx_cq_clean()
2831 struct be_adapter *adapter = rxo->adapter; in be_rx_cq_clean()
2841 rxcp = be_rx_compl_get(rxo); in be_rx_cq_clean()
2856 be_rx_compl_discard(rxo, rxcp); in be_rx_cq_clean()
3107 struct be_rx_obj *rxo; in be_rx_cqs_destroy() local
3110 for_all_rx_queues(adapter, rxo, i) { in be_rx_cqs_destroy()
3111 q = &rxo->cq; in be_rx_cqs_destroy()
3121 struct be_rx_obj *rxo; in be_rx_cqs_create() local
3140 for_all_rx_queues(adapter, rxo, i) { in be_rx_cqs_create()
3141 rxo->adapter = adapter; in be_rx_cqs_create()
3142 cq = &rxo->cq; in be_rx_cqs_create()
3148 u64_stats_init(&rxo->stats.sync); in be_rx_cqs_create()
3206 static int be_process_rx(struct be_rx_obj *rxo, struct napi_struct *napi, in be_process_rx() argument
3209 struct be_adapter *adapter = rxo->adapter; in be_process_rx()
3210 struct be_queue_info *rx_cq = &rxo->cq; in be_process_rx()
3216 rxcp = be_rx_compl_get(rxo); in be_process_rx()
3226 be_rx_compl_discard(rxo, rxcp); in be_process_rx()
3235 be_rx_compl_discard(rxo, rxcp); in be_process_rx()
3240 be_rx_compl_process_gro(rxo, napi, rxcp); in be_process_rx()
3242 be_rx_compl_process(rxo, napi, rxcp); in be_process_rx()
3246 be_rx_stats_update(rxo, rxcp); in be_process_rx()
3255 if (atomic_read(&rxo->q.used) < RX_FRAGS_REFILL_WM && in be_process_rx()
3256 !rxo->rx_post_starved) in be_process_rx()
3257 be_post_rx_frags(rxo, GFP_ATOMIC, in be_process_rx()
3299 struct be_rx_obj *rxo; in be_poll() local
3312 for_all_rx_queues_on_eq(adapter, eqo, rxo, i) { in be_poll()
3313 work = be_process_rx(rxo, napi, budget); in be_poll()
3568 struct be_rx_obj *rxo; in be_rx_qs_destroy() local
3571 for_all_rx_queues(adapter, rxo, i) { in be_rx_qs_destroy()
3572 q = &rxo->q; in be_rx_qs_destroy()
3581 be_rx_cq_clean(rxo); in be_rx_qs_destroy()
3583 be_post_rx_frags(rxo, GFP_KERNEL, in be_rx_qs_destroy()
3588 be_rx_cq_clean(rxo); in be_rx_qs_destroy()
3589 be_rxq_clean(rxo); in be_rx_qs_destroy()
3686 struct be_rx_obj *rxo; in be_rx_qs_create() local
3689 for_all_rx_queues(adapter, rxo, i) { in be_rx_qs_create()
3690 rc = be_queue_alloc(adapter, &rxo->q, RX_Q_LEN, in be_rx_qs_create()
3697 rxo = default_rxo(adapter); in be_rx_qs_create()
3698 rc = be_cmd_rxq_create(adapter, &rxo->q, rxo->cq.id, in be_rx_qs_create()
3700 false, &rxo->rss_id); in be_rx_qs_create()
3705 for_all_rss_queues(adapter, rxo, i) { in be_rx_qs_create()
3706 rc = be_cmd_rxq_create(adapter, &rxo->q, rxo->cq.id, in be_rx_qs_create()
3708 true, &rxo->rss_id); in be_rx_qs_create()
3715 for_all_rss_queues(adapter, rxo, i) { in be_rx_qs_create()
3718 rss->rsstable[j + i] = rxo->rss_id; in be_rx_qs_create()
3747 for_all_rx_queues(adapter, rxo, i) in be_rx_qs_create()
3748 be_post_rx_frags(rxo, GFP_KERNEL, RX_Q_LEN - 1); in be_rx_qs_create()
3797 struct be_rx_obj *rxo; in be_open() local
3814 for_all_rx_queues(adapter, rxo, i) in be_open()
3815 be_cq_notify(adapter, rxo->cq.id, true, 0); in be_open()
5623 struct be_rx_obj *rxo; in be_worker() local
5646 for_all_rx_queues(adapter, rxo, i) { in be_worker()
5650 if (rxo->rx_post_starved) in be_worker()
5651 be_post_rx_frags(rxo, GFP_KERNEL, MAX_RX_POST); in be_worker()