mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-09 22:50:41 +00:00
scsi: sun_esp: fix device reference leaks
Make sure to drop the reference to the dma device taken by of_find_device_by_node() on probe errors and on driver unbind. Fixes: 334ae614772b ("sparc: Kill SBUS DVMA layer.") Signed-off-by: Johan Hovold <johan@kernel.org> Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
This commit is contained in:
parent
4a1108d6ca
commit
f62f9ffdb5
@ -566,6 +566,7 @@ static int esp_sbus_probe(struct platform_device *op)
|
||||
struct device_node *dp = op->dev.of_node;
|
||||
struct platform_device *dma_of = NULL;
|
||||
int hme = 0;
|
||||
int ret;
|
||||
|
||||
if (dp->parent &&
|
||||
(!strcmp(dp->parent->name, "espdma") ||
|
||||
@ -580,7 +581,11 @@ static int esp_sbus_probe(struct platform_device *op)
|
||||
if (!dma_of)
|
||||
return -ENODEV;
|
||||
|
||||
return esp_sbus_probe_one(op, dma_of, hme);
|
||||
ret = esp_sbus_probe_one(op, dma_of, hme);
|
||||
if (ret)
|
||||
put_device(&dma_of->dev);
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
static int esp_sbus_remove(struct platform_device *op)
|
||||
@ -613,6 +618,8 @@ static int esp_sbus_remove(struct platform_device *op)
|
||||
|
||||
dev_set_drvdata(&op->dev, NULL);
|
||||
|
||||
put_device(&dma_of->dev);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user