Lines Matching refs:rcd
355 # define vmxnet3_getRxComp(dstrcd, rcd, tmp) do { \ argument
357 vmxnet3_RxCompToCPU((rcd), (tmp)); \
370 # define vmxnet3_getRxComp(dstrcd, rcd, tmp) (dstrcd) = (rcd) argument
779 vmxnet3_append_frag(struct sk_buff *skb, struct Vmxnet3_RxCompDesc *rcd, in vmxnet3_append_frag() argument
786 skb_frag_fill_page_desc(frag, rbi->page, 0, rcd->len); in vmxnet3_append_frag()
787 skb->data_len += rcd->len; in vmxnet3_append_frag()
1451 if (!gdesc->rcd.cnc && adapter->netdev->features & NETIF_F_RXCSUM) { in vmxnet3_rx_csum()
1452 if (gdesc->rcd.v4 && in vmxnet3_rx_csum()
1460 WARN_ON_ONCE(!(gdesc->rcd.tcp || gdesc->rcd.udp) && in vmxnet3_rx_csum()
1463 WARN_ON_ONCE(gdesc->rcd.frg && in vmxnet3_rx_csum()
1466 } else if (gdesc->rcd.v6 && (le32_to_cpu(gdesc->dword[3]) & in vmxnet3_rx_csum()
1473 WARN_ON_ONCE(!(gdesc->rcd.tcp || gdesc->rcd.udp) && in vmxnet3_rx_csum()
1476 WARN_ON_ONCE(gdesc->rcd.frg && in vmxnet3_rx_csum()
1480 if (gdesc->rcd.csum) { in vmxnet3_rx_csum()
1481 skb->csum = htons(gdesc->rcd.csum); in vmxnet3_rx_csum()
1494 vmxnet3_rx_error(struct vmxnet3_rx_queue *rq, struct Vmxnet3_RxCompDesc *rcd, in vmxnet3_rx_error() argument
1498 if (!rcd->fcs) in vmxnet3_rx_error()
1533 BUG_ON(gdesc->rcd.tcp == 0); in vmxnet3_get_hdr_len()
1546 if (gdesc->rcd.v4) { in vmxnet3_get_hdr_len()
1553 } else if (gdesc->rcd.v6) { in vmxnet3_get_hdr_len()
1609 struct Vmxnet3_RxCompDesc *rcd; in vmxnet3_rq_rx_complete() local
1619 vmxnet3_getRxComp(rcd, &rq->comp_ring.base[rq->comp_ring.next2proc].rcd, in vmxnet3_rq_rx_complete()
1621 while (rcd->gen == rq->comp_ring.gen) { in vmxnet3_rq_rx_complete()
1642 BUG_ON(rcd->rqID != rq->qid && rcd->rqID != rq->qid2 && in vmxnet3_rq_rx_complete()
1643 rcd->rqID != rq->dataRingQid); in vmxnet3_rq_rx_complete()
1644 idx = rcd->rxdIdx; in vmxnet3_rq_rx_complete()
1645 ring_idx = VMXNET3_GET_RING_IDX(adapter, rcd->rqID); in vmxnet3_rq_rx_complete()
1654 if (unlikely(rcd->eop && rcd->err)) { in vmxnet3_rq_rx_complete()
1655 vmxnet3_rx_error(rq, rcd, ctx, adapter); in vmxnet3_rq_rx_complete()
1659 if (rcd->sop && rcd->eop && vmxnet3_xdp_enabled(adapter)) { in vmxnet3_rq_rx_complete()
1663 if (VMXNET3_RX_DATA_RING(adapter, rcd->rqID)) { in vmxnet3_rq_rx_complete()
1671 act = vmxnet3_process_xdp(adapter, rq, rcd, rbi, rxd, in vmxnet3_rq_rx_complete()
1684 if (rcd->sop) { /* first buf of the pkt */ in vmxnet3_rq_rx_complete()
1689 (rcd->rqID != rq->qid && in vmxnet3_rq_rx_complete()
1690 rcd->rqID != rq->dataRingQid)); in vmxnet3_rq_rx_complete()
1696 if (unlikely(rcd->len == 0)) { in vmxnet3_rq_rx_complete()
1698 BUG_ON(!(rcd->sop && rcd->eop)); in vmxnet3_rq_rx_complete()
1708 if (rq->rx_ts_desc_size != 0 && rcd->ext2) { in vmxnet3_rq_rx_complete()
1718 VMXNET3_RX_DATA_RING(adapter, rcd->rqID); in vmxnet3_rq_rx_complete()
1719 len = rxDataRingUsed ? rcd->len : rbi->len; in vmxnet3_rq_rx_complete()
1726 sz = rcd->rxdIdx * rq->data_ring.desc_size; in vmxnet3_rq_rx_complete()
1729 rcd->len, in vmxnet3_rq_rx_complete()
1755 BUG_ON(rcd->len > rq->data_ring.desc_size); in vmxnet3_rq_rx_complete()
1758 sz = rcd->rxdIdx * rq->data_ring.desc_size; in vmxnet3_rq_rx_complete()
1760 &rq->data_ring.base[sz], rcd->len); in vmxnet3_rq_rx_complete()
1795 skb_put(ctx->skb, rcd->len); in vmxnet3_rq_rx_complete()
1798 rcd->type == VMXNET3_CDTYPE_RXCOMP_LRO) { in vmxnet3_rq_rx_complete()
1802 rcdlro = (struct Vmxnet3_RxCompDescExt *)rcd; in vmxnet3_rq_rx_complete()
1803 gdesc = (union Vmxnet3_GenericDesc *)rcd; in vmxnet3_rq_rx_complete()
1828 if (rcd->len) { in vmxnet3_rq_rx_complete()
1860 vmxnet3_append_frag(ctx->skb, rcd, rbi); in vmxnet3_rq_rx_complete()
1873 if (rcd->eop) { in vmxnet3_rq_rx_complete()
1878 if (rcd->rssType != VMXNET3_RCD_RSS_TYPE_NONE && in vmxnet3_rq_rx_complete()
1882 switch (rcd->rssType) { in vmxnet3_rq_rx_complete()
1898 le32_to_cpu(rcd->rssHash), in vmxnet3_rq_rx_complete()
1903 (union Vmxnet3_GenericDesc *)rcd); in vmxnet3_rq_rx_complete()
1905 if ((!rcd->tcp && !encap_lro) || in vmxnet3_rq_rx_complete()
1910 skb_shinfo(skb)->gso_type = rcd->v4 ? in vmxnet3_rq_rx_complete()
1920 (union Vmxnet3_GenericDesc *)rcd); in vmxnet3_rq_rx_complete()
1925 rcd->v4 ? SKB_GSO_TCPV4 : SKB_GSO_TCPV6; in vmxnet3_rq_rx_complete()
1936 if (unlikely(rcd->ts)) in vmxnet3_rq_rx_complete()
1937 __vlan_hwaccel_put_tag(skb, htons(ETH_P_8021Q), rcd->tci); in vmxnet3_rq_rx_complete()
2007 vmxnet3_getRxComp(rcd, in vmxnet3_rq_rx_complete()
2008 &rq->comp_ring.base[rq->comp_ring.next2proc].rcd, &rxComp); in vmxnet3_rq_rx_complete()