mirror of https://gitee.com/openkylin/linux.git
igbvf: Check for error on dma_map_single call
Ignoring the return value from a call to the kernel dma_map API functions can cause data corruption and system instability. Check the return value and take appropriate action. Signed-off-by: Greg Rose <gregory.v.rose@intel.com> Tested-by: Sibai Li <sibai.li@intel.com> Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
This commit is contained in:
parent
f9d08f165b
commit
91ffb8e0dc
|
@ -184,6 +184,13 @@ static void igbvf_alloc_rx_buffers(struct igbvf_ring *rx_ring,
|
||||||
buffer_info->page_offset,
|
buffer_info->page_offset,
|
||||||
PAGE_SIZE / 2,
|
PAGE_SIZE / 2,
|
||||||
DMA_FROM_DEVICE);
|
DMA_FROM_DEVICE);
|
||||||
|
if (dma_mapping_error(&pdev->dev,
|
||||||
|
buffer_info->page_dma)) {
|
||||||
|
__free_page(buffer_info->page);
|
||||||
|
buffer_info->page = NULL;
|
||||||
|
dev_err(&pdev->dev, "RX DMA map failed\n");
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!buffer_info->skb) {
|
if (!buffer_info->skb) {
|
||||||
|
@ -197,6 +204,12 @@ static void igbvf_alloc_rx_buffers(struct igbvf_ring *rx_ring,
|
||||||
buffer_info->dma = dma_map_single(&pdev->dev, skb->data,
|
buffer_info->dma = dma_map_single(&pdev->dev, skb->data,
|
||||||
bufsz,
|
bufsz,
|
||||||
DMA_FROM_DEVICE);
|
DMA_FROM_DEVICE);
|
||||||
|
if (dma_mapping_error(&pdev->dev, buffer_info->dma)) {
|
||||||
|
dev_kfree_skb(buffer_info->skb);
|
||||||
|
buffer_info->skb = NULL;
|
||||||
|
dev_err(&pdev->dev, "RX DMA map failed\n");
|
||||||
|
goto no_buffers;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
/* Refresh the desc even if buffer_addrs didn't change because
|
/* Refresh the desc even if buffer_addrs didn't change because
|
||||||
* each write-back erases this info. */
|
* each write-back erases this info. */
|
||||||
|
|
Loading…
Reference in New Issue