diff options
Diffstat (limited to 'drivers/net/cxgb4/sge.c')
-rw-r--r-- | drivers/net/cxgb4/sge.c | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/drivers/net/cxgb4/sge.c b/drivers/net/cxgb4/sge.c index 14adc58e71c3..d1f8f225e45a 100644 --- a/drivers/net/cxgb4/sge.c +++ b/drivers/net/cxgb4/sge.c | |||
@@ -1471,7 +1471,7 @@ EXPORT_SYMBOL(cxgb4_pktgl_to_skb); | |||
1471 | * Releases the pages of a packet gather list. We do not own the last | 1471 | * Releases the pages of a packet gather list. We do not own the last |
1472 | * page on the list and do not free it. | 1472 | * page on the list and do not free it. |
1473 | */ | 1473 | */ |
1474 | void t4_pktgl_free(const struct pkt_gl *gl) | 1474 | static void t4_pktgl_free(const struct pkt_gl *gl) |
1475 | { | 1475 | { |
1476 | int n; | 1476 | int n; |
1477 | const skb_frag_t *p; | 1477 | const skb_frag_t *p; |
@@ -1524,6 +1524,8 @@ static void do_gro(struct sge_eth_rxq *rxq, const struct pkt_gl *gl, | |||
1524 | skb->truesize += skb->data_len; | 1524 | skb->truesize += skb->data_len; |
1525 | skb->ip_summed = CHECKSUM_UNNECESSARY; | 1525 | skb->ip_summed = CHECKSUM_UNNECESSARY; |
1526 | skb_record_rx_queue(skb, rxq->rspq.idx); | 1526 | skb_record_rx_queue(skb, rxq->rspq.idx); |
1527 | if (rxq->rspq.netdev->features & NETIF_F_RXHASH) | ||
1528 | skb->rxhash = (__force u32)pkt->rsshdr.hash_val; | ||
1527 | 1529 | ||
1528 | if (unlikely(pkt->vlan_ex)) { | 1530 | if (unlikely(pkt->vlan_ex)) { |
1529 | struct port_info *pi = netdev_priv(rxq->rspq.netdev); | 1531 | struct port_info *pi = netdev_priv(rxq->rspq.netdev); |
@@ -1565,7 +1567,7 @@ int t4_ethrx_handler(struct sge_rspq *q, const __be64 *rsp, | |||
1565 | if (unlikely(*(u8 *)rsp == CPL_TRACE_PKT)) | 1567 | if (unlikely(*(u8 *)rsp == CPL_TRACE_PKT)) |
1566 | return handle_trace_pkt(q->adap, si); | 1568 | return handle_trace_pkt(q->adap, si); |
1567 | 1569 | ||
1568 | pkt = (void *)&rsp[1]; | 1570 | pkt = (const struct cpl_rx_pkt *)rsp; |
1569 | csum_ok = pkt->csum_calc && !pkt->err_vec; | 1571 | csum_ok = pkt->csum_calc && !pkt->err_vec; |
1570 | if ((pkt->l2info & htonl(RXF_TCP)) && | 1572 | if ((pkt->l2info & htonl(RXF_TCP)) && |
1571 | (q->netdev->features & NETIF_F_GRO) && csum_ok && !pkt->ip_frag) { | 1573 | (q->netdev->features & NETIF_F_GRO) && csum_ok && !pkt->ip_frag) { |
@@ -1583,6 +1585,9 @@ int t4_ethrx_handler(struct sge_rspq *q, const __be64 *rsp, | |||
1583 | __skb_pull(skb, RX_PKT_PAD); /* remove ethernet header padding */ | 1585 | __skb_pull(skb, RX_PKT_PAD); /* remove ethernet header padding */ |
1584 | skb->protocol = eth_type_trans(skb, q->netdev); | 1586 | skb->protocol = eth_type_trans(skb, q->netdev); |
1585 | skb_record_rx_queue(skb, q->idx); | 1587 | skb_record_rx_queue(skb, q->idx); |
1588 | if (skb->dev->features & NETIF_F_RXHASH) | ||
1589 | skb->rxhash = (__force u32)pkt->rsshdr.hash_val; | ||
1590 | |||
1586 | pi = netdev_priv(skb->dev); | 1591 | pi = netdev_priv(skb->dev); |
1587 | rxq->stats.pkts++; | 1592 | rxq->stats.pkts++; |
1588 | 1593 | ||
@@ -2047,7 +2052,7 @@ int t4_sge_alloc_rxq(struct adapter *adap, struct sge_rspq *iq, bool fwevtq, | |||
2047 | adap->sge.ingr_map[iq->cntxt_id] = iq; | 2052 | adap->sge.ingr_map[iq->cntxt_id] = iq; |
2048 | 2053 | ||
2049 | if (fl) { | 2054 | if (fl) { |
2050 | fl->cntxt_id = htons(c.fl0id); | 2055 | fl->cntxt_id = ntohs(c.fl0id); |
2051 | fl->avail = fl->pend_cred = 0; | 2056 | fl->avail = fl->pend_cred = 0; |
2052 | fl->pidx = fl->cidx = 0; | 2057 | fl->pidx = fl->cidx = 0; |
2053 | fl->alloc_failed = fl->large_alloc_failed = fl->starving = 0; | 2058 | fl->alloc_failed = fl->large_alloc_failed = fl->starving = 0; |