Lines Matching refs:rcd

290 #   define vmxnet3_getRxComp(dstrcd, rcd, tmp) do { \  argument
292 vmxnet3_RxCompToCPU((rcd), (tmp)); \
305 # define vmxnet3_getRxComp(dstrcd, rcd, tmp) (dstrcd) = (rcd) argument
659 vmxnet3_append_frag(struct sk_buff *skb, struct Vmxnet3_RxCompDesc *rcd, in vmxnet3_append_frag() argument
668 skb_frag_size_set(frag, rcd->len); in vmxnet3_append_frag()
669 skb->data_len += rcd->len; in vmxnet3_append_frag()
1234 if (!gdesc->rcd.cnc && adapter->netdev->features & NETIF_F_RXCSUM) { in vmxnet3_rx_csum()
1235 if (gdesc->rcd.v4 && in vmxnet3_rx_csum()
1239 WARN_ON_ONCE(!(gdesc->rcd.tcp || gdesc->rcd.udp) && in vmxnet3_rx_csum()
1242 WARN_ON_ONCE(gdesc->rcd.frg && in vmxnet3_rx_csum()
1245 } else if (gdesc->rcd.v6 && (le32_to_cpu(gdesc->dword[3]) & in vmxnet3_rx_csum()
1248 WARN_ON_ONCE(!(gdesc->rcd.tcp || gdesc->rcd.udp) && in vmxnet3_rx_csum()
1251 WARN_ON_ONCE(gdesc->rcd.frg && in vmxnet3_rx_csum()
1255 if (gdesc->rcd.csum) { in vmxnet3_rx_csum()
1256 skb->csum = htons(gdesc->rcd.csum); in vmxnet3_rx_csum()
1269 vmxnet3_rx_error(struct vmxnet3_rx_queue *rq, struct Vmxnet3_RxCompDesc *rcd, in vmxnet3_rx_error() argument
1273 if (!rcd->fcs) in vmxnet3_rx_error()
1308 BUG_ON(gdesc->rcd.tcp == 0); in vmxnet3_get_hdr_len()
1321 if (gdesc->rcd.v4) { in vmxnet3_get_hdr_len()
1328 } else if (gdesc->rcd.v6) { in vmxnet3_get_hdr_len()
1360 struct Vmxnet3_RxCompDesc *rcd; in vmxnet3_rq_rx_complete() local
1367 vmxnet3_getRxComp(rcd, &rq->comp_ring.base[rq->comp_ring.next2proc].rcd, in vmxnet3_rq_rx_complete()
1369 while (rcd->gen == rq->comp_ring.gen) { in vmxnet3_rq_rx_complete()
1390 BUG_ON(rcd->rqID != rq->qid && rcd->rqID != rq->qid2 && in vmxnet3_rq_rx_complete()
1391 rcd->rqID != rq->dataRingQid); in vmxnet3_rq_rx_complete()
1392 idx = rcd->rxdIdx; in vmxnet3_rq_rx_complete()
1393 ring_idx = VMXNET3_GET_RING_IDX(adapter, rcd->rqID); in vmxnet3_rq_rx_complete()
1402 if (unlikely(rcd->eop && rcd->err)) { in vmxnet3_rq_rx_complete()
1403 vmxnet3_rx_error(rq, rcd, ctx, adapter); in vmxnet3_rq_rx_complete()
1407 if (rcd->sop) { /* first buf of the pkt */ in vmxnet3_rq_rx_complete()
1412 (rcd->rqID != rq->qid && in vmxnet3_rq_rx_complete()
1413 rcd->rqID != rq->dataRingQid)); in vmxnet3_rq_rx_complete()
1418 if (unlikely(rcd->len == 0)) { in vmxnet3_rq_rx_complete()
1420 BUG_ON(!(rcd->sop && rcd->eop)); in vmxnet3_rq_rx_complete()
1431 VMXNET3_RX_DATA_RING(adapter, rcd->rqID); in vmxnet3_rq_rx_complete()
1432 len = rxDataRingUsed ? rcd->len : rbi->len; in vmxnet3_rq_rx_complete()
1449 BUG_ON(rcd->len > rq->data_ring.desc_size); in vmxnet3_rq_rx_complete()
1452 sz = rcd->rxdIdx * rq->data_ring.desc_size; in vmxnet3_rq_rx_complete()
1454 &rq->data_ring.base[sz], rcd->len); in vmxnet3_rq_rx_complete()
1489 if (rcd->rssType != VMXNET3_RCD_RSS_TYPE_NONE && in vmxnet3_rq_rx_complete()
1492 le32_to_cpu(rcd->rssHash), in vmxnet3_rq_rx_complete()
1495 skb_put(ctx->skb, rcd->len); in vmxnet3_rq_rx_complete()
1498 rcd->type == VMXNET3_CDTYPE_RXCOMP_LRO) { in vmxnet3_rq_rx_complete()
1502 rcdlro = (struct Vmxnet3_RxCompDescExt *)rcd; in vmxnet3_rq_rx_complete()
1503 gdesc = (union Vmxnet3_GenericDesc *)rcd; in vmxnet3_rq_rx_complete()
1528 if (rcd->len) { in vmxnet3_rq_rx_complete()
1560 vmxnet3_append_frag(ctx->skb, rcd, rbi); in vmxnet3_rq_rx_complete()
1572 if (rcd->eop) { in vmxnet3_rq_rx_complete()
1577 (union Vmxnet3_GenericDesc *)rcd); in vmxnet3_rq_rx_complete()
1579 if ((!rcd->tcp && !encap_lro) || in vmxnet3_rq_rx_complete()
1584 skb_shinfo(skb)->gso_type = rcd->v4 ? in vmxnet3_rq_rx_complete()
1592 (union Vmxnet3_GenericDesc *)rcd); in vmxnet3_rq_rx_complete()
1597 rcd->v4 ? SKB_GSO_TCPV4 : SKB_GSO_TCPV6; in vmxnet3_rq_rx_complete()
1608 if (unlikely(rcd->ts)) in vmxnet3_rq_rx_complete()
1609 __vlan_hwaccel_put_tag(skb, htons(ETH_P_8021Q), rcd->tci); in vmxnet3_rq_rx_complete()
1651 vmxnet3_getRxComp(rcd, in vmxnet3_rq_rx_complete()
1652 &rq->comp_ring.base[rq->comp_ring.next2proc].rcd, &rxComp); in vmxnet3_rq_rx_complete()