net: ethernet: SP7021: fix a use after free of skb->len
The netif_receive_skb() function frees "skb" so store skb->len before
it is freed.
Fixes: fd3040b939
("net: ethernet: Add driver for Sunplus SP7021")
Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
Link: https://lore.kernel.org/r/YoUuy4iTjFAcSn03@kili
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
This commit is contained in:
Родитель
f01cdcf891
Коммит
df98714e43
|
@ -29,6 +29,7 @@ int spl2sw_rx_poll(struct napi_struct *napi, int budget)
|
|||
u32 mask;
|
||||
int port;
|
||||
u32 cmd;
|
||||
u32 len;
|
||||
|
||||
/* Process high-priority queue and then low-priority queue. */
|
||||
for (queue = 0; queue < RX_DESC_QUEUE_NUM; queue++) {
|
||||
|
@ -63,10 +64,11 @@ int spl2sw_rx_poll(struct napi_struct *napi, int budget)
|
|||
skb_put(skb, pkg_len - 4); /* Minus FCS */
|
||||
skb->ip_summed = CHECKSUM_NONE;
|
||||
skb->protocol = eth_type_trans(skb, comm->ndev[port]);
|
||||
len = skb->len;
|
||||
netif_receive_skb(skb);
|
||||
|
||||
stats->rx_packets++;
|
||||
stats->rx_bytes += skb->len;
|
||||
stats->rx_bytes += len;
|
||||
|
||||
/* Allocate a new skb for receiving. */
|
||||
new_skb = netdev_alloc_skb(NULL, comm->rx_desc_buff_size);
|
||||
|
|
Загрузка…
Ссылка в новой задаче