diff options
author | Jan Glauber <jglauber@cavium.com> | 2017-05-22 13:09:21 +0200 |
---|---|---|
committer | Ulf Hansson <ulf.hansson@linaro.org> | 2017-05-22 18:01:46 +0200 |
commit | 8fb83b142823cdd1f85f78dcf9e861e9033919f9 (patch) | |
tree | b95b866597e850c25967f03c6f6fe687b6f041b9 /drivers/mmc/host/cavium-thunderx.c | |
parent | c2372c20425bd75a5527b3e2204059762190f6ca (diff) | |
download | lwn-8fb83b142823cdd1f85f78dcf9e861e9033919f9.tar.gz lwn-8fb83b142823cdd1f85f78dcf9e861e9033919f9.zip |
mmc: cavium: Fix probing race with regulator
If the regulator probing is not yet finished this driver
might catch a -EPROBE_DEFER. Returning after this condition
did not remove the created platform device. On a repeated
call to the probe function the of_platform_device_create
fails.
Calling of_platform_device_destroy after EPROBE_DEFER resolves
this bug.
Signed-off-by: Jan Glauber <jglauber@cavium.com>
Signed-off-by: Ulf Hansson <ulf.hansson@linaro.org>
Diffstat (limited to 'drivers/mmc/host/cavium-thunderx.c')
-rw-r--r-- | drivers/mmc/host/cavium-thunderx.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/drivers/mmc/host/cavium-thunderx.c b/drivers/mmc/host/cavium-thunderx.c index fe3d77267cd6..b9cc95998799 100644 --- a/drivers/mmc/host/cavium-thunderx.c +++ b/drivers/mmc/host/cavium-thunderx.c @@ -146,6 +146,12 @@ static int thunder_mmc_probe(struct pci_dev *pdev, return 0; error: + for (i = 0; i < CAVIUM_MAX_MMC; i++) { + if (host->slot[i]) + cvm_mmc_of_slot_remove(host->slot[i]); + if (host->slot_pdev[i]) + of_platform_device_destroy(&host->slot_pdev[i]->dev, NULL); + } clk_disable_unprepare(host->clk); return ret; } |