Commit b89e1399 authored by Sylwester Nawrocki's avatar Sylwester Nawrocki Committed by Florian Tobias Schandinat

video: exynos mipi dsi: Avoid races in probe()

Make sure all resources are initialized before interrupt handler is
registered. Pass full platform device name to request_irq() so it
can be distinguished which device has requested an interrupt in cases
there are multiple instances in the system.

Also enable voltage regulators regardless of they have been enabled
by bootloader or not, to make sure other drivers using same regulators
don't disable them unexpectedly.
Signed-off-by: default avatarSylwester Nawrocki <s.nawrocki@samsung.com>
Signed-off-by: default avatarDonghwa Lee <dh09.lee@samsung.com>
Signed-off-by: default avatarInki Dae <inki.dae@samsung.com>
Signed-off-by: default avatarKyungmin Park <kyungmin.park@samsung.com>
Signed-off-by: default avatarFlorian Tobias Schandinat <FlorianSchandinat@gmx.de>
parent 3bfc9b83
...@@ -415,27 +415,30 @@ static int exynos_mipi_dsi_probe(struct platform_device *pdev) ...@@ -415,27 +415,30 @@ static int exynos_mipi_dsi_probe(struct platform_device *pdev)
goto err_platform_get_irq; goto err_platform_get_irq;
} }
init_completion(&dsim_wr_comp);
init_completion(&dsim_rd_comp);
platform_set_drvdata(pdev, dsim);
ret = request_irq(dsim->irq, exynos_mipi_dsi_interrupt_handler, ret = request_irq(dsim->irq, exynos_mipi_dsi_interrupt_handler,
IRQF_SHARED, pdev->name, dsim); IRQF_SHARED, dev_name(&pdev->dev), dsim);
if (ret != 0) { if (ret != 0) {
dev_err(&pdev->dev, "failed to request dsim irq\n"); dev_err(&pdev->dev, "failed to request dsim irq\n");
ret = -EINVAL; ret = -EINVAL;
goto err_bind; goto err_bind;
} }
init_completion(&dsim_wr_comp); /* enable interrupts */
init_completion(&dsim_rd_comp);
/* enable interrupt */
exynos_mipi_dsi_init_interrupt(dsim); exynos_mipi_dsi_init_interrupt(dsim);
/* initialize mipi-dsi client(lcd panel). */ /* initialize mipi-dsi client(lcd panel). */
if (dsim_ddi->dsim_lcd_drv && dsim_ddi->dsim_lcd_drv->probe) if (dsim_ddi->dsim_lcd_drv && dsim_ddi->dsim_lcd_drv->probe)
dsim_ddi->dsim_lcd_drv->probe(dsim_ddi->dsim_lcd_dev); dsim_ddi->dsim_lcd_drv->probe(dsim_ddi->dsim_lcd_dev);
/* in case that mipi got enabled at bootloader. */ /* in case mipi-dsi has been enabled by bootloader */
if (dsim_pd->enabled) if (dsim_pd->enabled) {
goto out; exynos_mipi_regulator_enable(dsim);
goto done;
}
/* lcd panel power on. */ /* lcd panel power on. */
if (dsim_ddi->dsim_lcd_drv && dsim_ddi->dsim_lcd_drv->power_on) if (dsim_ddi->dsim_lcd_drv && dsim_ddi->dsim_lcd_drv->power_on)
...@@ -455,12 +458,11 @@ static int exynos_mipi_dsi_probe(struct platform_device *pdev) ...@@ -455,12 +458,11 @@ static int exynos_mipi_dsi_probe(struct platform_device *pdev)
dsim->suspended = false; dsim->suspended = false;
out: done:
platform_set_drvdata(pdev, dsim); platform_set_drvdata(pdev, dsim);
dev_dbg(&pdev->dev, "mipi-dsi driver(%s mode) has been probed.\n", dev_dbg(&pdev->dev, "%s() completed sucessfuly (%s mode)\n", __func__,
(dsim_config->e_interface == DSIM_COMMAND) ? dsim_config->e_interface == DSIM_COMMAND ? "CPU" : "RGB");
"CPU" : "RGB");
return 0; return 0;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment