diff options
Diffstat (limited to 'drivers/net/mlx4/en_tx.c')
-rw-r--r-- | drivers/net/mlx4/en_tx.c | 29 |
1 files changed, 7 insertions, 22 deletions
diff --git a/drivers/net/mlx4/en_tx.c b/drivers/net/mlx4/en_tx.c index 5dc7466ad035..08c43f2ae72b 100644 --- a/drivers/net/mlx4/en_tx.c +++ b/drivers/net/mlx4/en_tx.c | |||
@@ -515,16 +515,9 @@ static int get_real_size(struct sk_buff *skb, struct net_device *dev, | |||
515 | else { | 515 | else { |
516 | if (netif_msg_tx_err(priv)) | 516 | if (netif_msg_tx_err(priv)) |
517 | en_warn(priv, "Non-linear headers\n"); | 517 | en_warn(priv, "Non-linear headers\n"); |
518 | dev_kfree_skb_any(skb); | ||
519 | return 0; | 518 | return 0; |
520 | } | 519 | } |
521 | } | 520 | } |
522 | if (unlikely(*lso_header_size > MAX_LSO_HDR_SIZE)) { | ||
523 | if (netif_msg_tx_err(priv)) | ||
524 | en_warn(priv, "LSO header size too big\n"); | ||
525 | dev_kfree_skb_any(skb); | ||
526 | return 0; | ||
527 | } | ||
528 | } else { | 521 | } else { |
529 | *lso_header_size = 0; | 522 | *lso_header_size = 0; |
530 | if (!is_inline(skb, NULL)) | 523 | if (!is_inline(skb, NULL)) |
@@ -616,13 +609,9 @@ int mlx4_en_xmit(struct sk_buff *skb, struct net_device *dev) | |||
616 | int lso_header_size; | 609 | int lso_header_size; |
617 | void *fragptr; | 610 | void *fragptr; |
618 | 611 | ||
619 | if (unlikely(!skb->len)) { | ||
620 | dev_kfree_skb_any(skb); | ||
621 | return NETDEV_TX_OK; | ||
622 | } | ||
623 | real_size = get_real_size(skb, dev, &lso_header_size); | 612 | real_size = get_real_size(skb, dev, &lso_header_size); |
624 | if (unlikely(!real_size)) | 613 | if (unlikely(!real_size)) |
625 | return NETDEV_TX_OK; | 614 | goto tx_drop; |
626 | 615 | ||
627 | /* Allign descriptor to TXBB size */ | 616 | /* Allign descriptor to TXBB size */ |
628 | desc_size = ALIGN(real_size, TXBB_SIZE); | 617 | desc_size = ALIGN(real_size, TXBB_SIZE); |
@@ -630,8 +619,7 @@ int mlx4_en_xmit(struct sk_buff *skb, struct net_device *dev) | |||
630 | if (unlikely(nr_txbb > MAX_DESC_TXBBS)) { | 619 | if (unlikely(nr_txbb > MAX_DESC_TXBBS)) { |
631 | if (netif_msg_tx_err(priv)) | 620 | if (netif_msg_tx_err(priv)) |
632 | en_warn(priv, "Oversized header or SG list\n"); | 621 | en_warn(priv, "Oversized header or SG list\n"); |
633 | dev_kfree_skb_any(skb); | 622 | goto tx_drop; |
634 | return NETDEV_TX_OK; | ||
635 | } | 623 | } |
636 | 624 | ||
637 | tx_ind = skb->queue_mapping; | 625 | tx_ind = skb->queue_mapping; |
@@ -653,14 +641,6 @@ int mlx4_en_xmit(struct sk_buff *skb, struct net_device *dev) | |||
653 | return NETDEV_TX_BUSY; | 641 | return NETDEV_TX_BUSY; |
654 | } | 642 | } |
655 | 643 | ||
656 | /* Now that we know what Tx ring to use */ | ||
657 | if (unlikely(!priv->port_up)) { | ||
658 | if (netif_msg_tx_err(priv)) | ||
659 | en_warn(priv, "xmit: port down!\n"); | ||
660 | dev_kfree_skb_any(skb); | ||
661 | return NETDEV_TX_OK; | ||
662 | } | ||
663 | |||
664 | /* Track current inflight packets for performance analysis */ | 644 | /* Track current inflight packets for performance analysis */ |
665 | AVG_PERF_COUNTER(priv->pstats.inflight_avg, | 645 | AVG_PERF_COUNTER(priv->pstats.inflight_avg, |
666 | (u32) (ring->prod - ring->cons - 1)); | 646 | (u32) (ring->prod - ring->cons - 1)); |
@@ -785,5 +765,10 @@ int mlx4_en_xmit(struct sk_buff *skb, struct net_device *dev) | |||
785 | mlx4_en_xmit_poll(priv, tx_ind); | 765 | mlx4_en_xmit_poll(priv, tx_ind); |
786 | 766 | ||
787 | return 0; | 767 | return 0; |
768 | |||
769 | tx_drop: | ||
770 | dev_kfree_skb_any(skb); | ||
771 | priv->stats.tx_dropped++; | ||
772 | return NETDEV_TX_OK; | ||
788 | } | 773 | } |
789 | 774 | ||