mirror of
https://github.com/hardkernel/linux.git
synced 2026-06-06 10:58:48 +09:00
ethernet: atheros: fix return value check in atl1c_tso_csum()
[ Upstream commit 8d01da0a1d ]
in atl1c_tso_csum, it should check the return value of pskb_trim(),
and return an error code if an unexpected value is returned
by pskb_trim().
Signed-off-by: Yuanjun Gong <ruc_gongyuanjun@163.com>
Reviewed-by: Simon Horman <simon.horman@corigine.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
0f7b43a577
commit
328fcde050
@@ -2104,8 +2104,11 @@ static int atl1c_tso_csum(struct atl1c_adapter *adapter,
|
|||||||
real_len = (((unsigned char *)ip_hdr(skb) - skb->data)
|
real_len = (((unsigned char *)ip_hdr(skb) - skb->data)
|
||||||
+ ntohs(ip_hdr(skb)->tot_len));
|
+ ntohs(ip_hdr(skb)->tot_len));
|
||||||
|
|
||||||
if (real_len < skb->len)
|
if (real_len < skb->len) {
|
||||||
pskb_trim(skb, real_len);
|
err = pskb_trim(skb, real_len);
|
||||||
|
if (err)
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
|
||||||
hdr_len = skb_tcp_all_headers(skb);
|
hdr_len = skb_tcp_all_headers(skb);
|
||||||
if (unlikely(skb->len == hdr_len)) {
|
if (unlikely(skb->len == hdr_len)) {
|
||||||
|
|||||||
Reference in New Issue
Block a user