mirror of
https://github.com/torvalds/linux.git
synced 2026-06-07 05:55:44 +02:00
ethernet: sun: Free the coherent when failing in probing
[ Upstream commit bb77bd31c2 ]
When the driver fails to register net device, it should free the DMA
region first, and then do other cleanup.
Signed-off-by: Zheyu Ma <zheyuma97@gmail.com>
Reviewed-by: Andrew Lunn <andrew@lunn.ch>
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
parent
3c84471925
commit
fc9a35627c
|
|
@ -3163,7 +3163,7 @@ static int happy_meal_pci_probe(struct pci_dev *pdev,
|
||||||
if (err) {
|
if (err) {
|
||||||
printk(KERN_ERR "happymeal(PCI): Cannot register net device, "
|
printk(KERN_ERR "happymeal(PCI): Cannot register net device, "
|
||||||
"aborting.\n");
|
"aborting.\n");
|
||||||
goto err_out_iounmap;
|
goto err_out_free_coherent;
|
||||||
}
|
}
|
||||||
|
|
||||||
pci_set_drvdata(pdev, hp);
|
pci_set_drvdata(pdev, hp);
|
||||||
|
|
@ -3196,6 +3196,10 @@ static int happy_meal_pci_probe(struct pci_dev *pdev,
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
err_out_free_coherent:
|
||||||
|
dma_free_coherent(hp->dma_dev, PAGE_SIZE,
|
||||||
|
hp->happy_block, hp->hblock_dvma);
|
||||||
|
|
||||||
err_out_iounmap:
|
err_out_iounmap:
|
||||||
iounmap(hp->gregs);
|
iounmap(hp->gregs);
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue
Block a user