et131x: Add missing check after DMA map
[ Upstream commit d61f6cb6f6ef3c70d2ccc0d9c85c508cb8017da9 ] The DMA map functions can fail and should be tested for errors. If the mapping fails, unmap and return an error. Signed-off-by: Thomas Fourier <fourier.thomas@gmail.com> Acked-by: Mark Einon <mark.einon@gmail.com> Reviewed-by: Simon Horman <horms@kernel.org> Link: https://patch.msgid.link/20250716094733.28734-2-fourier.thomas@gmail.com Signed-off-by: Jakub Kicinski <kuba@kernel.org> Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
71c3a735bb
commit
8ca79651e1
@@ -2460,6 +2460,10 @@ static int nic_send_packet(struct et131x_adapter *adapter, struct tcb *tcb)
|
||||
skb->data,
|
||||
skb_headlen(skb),
|
||||
DMA_TO_DEVICE);
|
||||
if (dma_mapping_error(&adapter->pdev->dev,
|
||||
dma_addr))
|
||||
return -ENOMEM;
|
||||
|
||||
desc[frag].addr_lo = lower_32_bits(dma_addr);
|
||||
desc[frag].addr_hi = upper_32_bits(dma_addr);
|
||||
frag++;
|
||||
@@ -2469,6 +2473,10 @@ static int nic_send_packet(struct et131x_adapter *adapter, struct tcb *tcb)
|
||||
skb->data,
|
||||
skb_headlen(skb) / 2,
|
||||
DMA_TO_DEVICE);
|
||||
if (dma_mapping_error(&adapter->pdev->dev,
|
||||
dma_addr))
|
||||
return -ENOMEM;
|
||||
|
||||
desc[frag].addr_lo = lower_32_bits(dma_addr);
|
||||
desc[frag].addr_hi = upper_32_bits(dma_addr);
|
||||
frag++;
|
||||
@@ -2479,6 +2487,10 @@ static int nic_send_packet(struct et131x_adapter *adapter, struct tcb *tcb)
|
||||
skb_headlen(skb) / 2,
|
||||
skb_headlen(skb) / 2,
|
||||
DMA_TO_DEVICE);
|
||||
if (dma_mapping_error(&adapter->pdev->dev,
|
||||
dma_addr))
|
||||
goto unmap_first_out;
|
||||
|
||||
desc[frag].addr_lo = lower_32_bits(dma_addr);
|
||||
desc[frag].addr_hi = upper_32_bits(dma_addr);
|
||||
frag++;
|
||||
@@ -2490,6 +2502,9 @@ static int nic_send_packet(struct et131x_adapter *adapter, struct tcb *tcb)
|
||||
0,
|
||||
desc[frag].len_vlan,
|
||||
DMA_TO_DEVICE);
|
||||
if (dma_mapping_error(&adapter->pdev->dev, dma_addr))
|
||||
goto unmap_out;
|
||||
|
||||
desc[frag].addr_lo = lower_32_bits(dma_addr);
|
||||
desc[frag].addr_hi = upper_32_bits(dma_addr);
|
||||
frag++;
|
||||
@@ -2579,6 +2594,27 @@ static int nic_send_packet(struct et131x_adapter *adapter, struct tcb *tcb)
|
||||
&adapter->regs->global.watchdog_timer);
|
||||
}
|
||||
return 0;
|
||||
|
||||
unmap_out:
|
||||
// Unmap the body of the packet with map_page
|
||||
while (--i) {
|
||||
frag--;
|
||||
dma_addr = desc[frag].addr_lo;
|
||||
dma_addr |= (u64)desc[frag].addr_hi << 32;
|
||||
dma_unmap_page(&adapter->pdev->dev, dma_addr,
|
||||
desc[frag].len_vlan, DMA_TO_DEVICE);
|
||||
}
|
||||
|
||||
unmap_first_out:
|
||||
// Unmap the header with map_single
|
||||
while (frag--) {
|
||||
dma_addr = desc[frag].addr_lo;
|
||||
dma_addr |= (u64)desc[frag].addr_hi << 32;
|
||||
dma_unmap_single(&adapter->pdev->dev, dma_addr,
|
||||
desc[frag].len_vlan, DMA_TO_DEVICE);
|
||||
}
|
||||
|
||||
return -ENOMEM;
|
||||
}
|
||||
|
||||
static int send_packet(struct sk_buff *skb, struct et131x_adapter *adapter)
|
||||
|
||||
Reference in New Issue
Block a user