[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <1481095805-25010-1-git-send-email-zhouzhouyi@gmail.com>
Date: Wed, 7 Dec 2016 15:30:05 +0800
From: Zhouyi Zhou <zhouzhouyi@...il.com>
To: <faisal.latif@...el.com>, <dledford@...hat.com>,
<sean.hefty@...el.com>, <hal.rosenstock@...il.com>,
<eric.dumazet@...il.com>, <linux-rdma@...r.kernel.org>,
<linux-kernel@...r.kernel.org>
Cc: Zhouyi Zhou <zhouzhouyi@...il.com>,
Zhouyi Zhou <yizhouzhou@....ac.cn>
Subject: [PATCH 1/1] infiniband: nes: return value of skb_linearize should be handled
Return value of skb_linearize should be handled in function
nes_netdev_start_xmit.
Compiled in x86_64
Signed-off-by: Zhouyi Zhou <yizhouzhou@....ac.cn>
Reviewed-by: Yuval Shaia <yuval.shaia@...cle.com>
Reviewed-by: Eric Dumazet <eric.dumazet@...il.com>
---
drivers/infiniband/hw/nes/nes_nic.c | 8 ++++++--
1 file changed, 6 insertions(+), 2 deletions(-)
diff --git a/drivers/infiniband/hw/nes/nes_nic.c b/drivers/infiniband/hw/nes/nes_nic.c
index 2b27d13..dfd1f57 100644
--- a/drivers/infiniband/hw/nes/nes_nic.c
+++ b/drivers/infiniband/hw/nes/nes_nic.c
@@ -662,10 +662,14 @@ static int nes_netdev_start_xmit(struct sk_buff *skb, struct net_device *netdev)
nesnic->sq_head &= nesnic->sq_size-1;
}
} else {
- nesvnic->linearized_skbs++;
hoffset = skb_transport_header(skb) - skb->data;
nhoffset = skb_network_header(skb) - skb->data;
- skb_linearize(skb);
+ if (skb_linearize(skb)) {
+ nesvnic->tx_sw_dropped++;
+ kfree_skb(skb);
+ return NETDEV_TX_OK;
+ }
+ nesvnic->linearized_skbs++;
skb_set_transport_header(skb, hoffset);
skb_set_network_header(skb, nhoffset);
if (!nes_nic_send(skb, netdev))
--
1.9.1
Powered by blists - more mailing lists