if (IS_ERR(reset))
return PTR_ERR(reset);
- host = spi_alloc_host(dev, sizeof(*bs));
- if (!host) {
- dev_err(dev, "out of memory\n");
+ host = devm_spi_alloc_host(dev, sizeof(*bs));
+ if (!host)
return -ENOMEM;
- }
bs = spi_controller_get_devdata(host);
init_completion(&bs->done);
bs->pdev = pdev;
bs->regs = devm_platform_get_and_ioremap_resource(pdev, 0, &r);
- if (IS_ERR(bs->regs)) {
- ret = PTR_ERR(bs->regs);
- goto out_err;
- }
+ if (IS_ERR(bs->regs))
+ return PTR_ERR(bs->regs);
bs->irq = irq;
bs->clk = clk;
pdev->name, host);
if (ret) {
dev_err(dev, "unable to request irq\n");
- goto out_err;
+ return ret;
}
host->bus_num = bus_num;
/* Initialize hardware */
ret = clk_prepare_enable(bs->clk);
if (ret)
- goto out_err;
+ return ret;
ret = reset_control_reset(reset);
if (ret) {
out_clk_disable:
clk_disable_unprepare(clk);
-out_err:
- spi_controller_put(host);
+
return ret;
}
struct spi_controller *host = platform_get_drvdata(pdev);
struct bcm63xx_spi *bs = spi_controller_get_devdata(host);
- spi_controller_get(host);
-
spi_unregister_controller(host);
/* reset spi block */
/* HW shutdown */
clk_disable_unprepare(bs->clk);
-
- spi_controller_put(host);
}
static int bcm63xx_spi_suspend(struct device *dev)