aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--net/core/pktgen.c26
1 files changed, 14 insertions, 12 deletions
diff --git a/net/core/pktgen.c b/net/core/pktgen.c
index 2456bd5b086f..bce9bf4b4a62 100644
--- a/net/core/pktgen.c
+++ b/net/core/pktgen.c
@@ -3424,27 +3424,29 @@ static void pktgen_xmit(struct pktgen_dev *pkt_dev)
3424 pkt_dev->last_ok = 0; 3424 pkt_dev->last_ok = 0;
3425 else { 3425 else {
3426 atomic_inc(&(pkt_dev->skb->users)); 3426 atomic_inc(&(pkt_dev->skb->users));
3427 retry_now: 3427
3428 retry_now:
3428 ret = (*xmit)(pkt_dev->skb, odev); 3429 ret = (*xmit)(pkt_dev->skb, odev);
3429 if (likely(ret == NETDEV_TX_OK)) { 3430 switch (ret) {
3431 case NETDEV_TX_OK:
3430 txq_trans_update(txq); 3432 txq_trans_update(txq);
3431 pkt_dev->last_ok = 1; 3433 pkt_dev->last_ok = 1;
3432 pkt_dev->sofar++; 3434 pkt_dev->sofar++;
3433 pkt_dev->seq_num++; 3435 pkt_dev->seq_num++;
3434 pkt_dev->tx_bytes += pkt_dev->cur_pkt_size; 3436 pkt_dev->tx_bytes += pkt_dev->cur_pkt_size;
3435 3437 break;
3436 } else if (ret == NETDEV_TX_LOCKED 3438 case NETDEV_TX_LOCKED:
3437 && (odev->features & NETIF_F_LLTX)) {
3438 cpu_relax(); 3439 cpu_relax();
3439 goto retry_now; 3440 goto retry_now;
3440 } else { /* Retry it next time */ 3441 default: /* Drivers are not supposed to return other values! */
3441 3442 if (net_ratelimit())
3442 atomic_dec(&(pkt_dev->skb->users)); 3443 pr_info("pktgen: %s xmit error: %d\n",
3443 3444 odev->name, ret);
3444 if (debug && net_ratelimit())
3445 printk(KERN_INFO "pktgen: Hard xmit error\n");
3446
3447 pkt_dev->errors++; 3445 pkt_dev->errors++;
3446 /* fallthru */
3447 case NETDEV_TX_BUSY:
3448 /* Retry it next time */
3449 atomic_dec(&(pkt_dev->skb->users));
3448 pkt_dev->last_ok = 0; 3450 pkt_dev->last_ok = 0;
3449 } 3451 }
3450 3452