From: Sandor Yu Date: Wed, 11 Feb 2015 08:12:36 +0000 (+0800) Subject: MLK-10232-1: vadc: Add vadc to generic pm domain X-Git-Url: https://git.karo-electronics.de/?p=karo-tx-linux.git;a=commitdiff_plain;h=905ac59a91ad37d3ca0113305246802768e5e007 MLK-10232-1: vadc: Add vadc to generic pm domain Vadc in the dispmix power domian, the register will been reset when dispmix power off, add vadc to generic pm domain, dispmix will not power off when vadc driver loading. Signed-off-by: Sandor Yu (cherry picked from commit e06f7339c01d6f77a94cfc8fc22276d03841fecf) --- diff --git a/drivers/media/platform/mxc/subdev/mxc_vadc.c b/drivers/media/platform/mxc/subdev/mxc_vadc.c index e54c3f21264f..f77044f895b7 100644 --- a/drivers/media/platform/mxc/subdev/mxc_vadc.c +++ b/drivers/media/platform/mxc/subdev/mxc_vadc.c @@ -28,6 +28,7 @@ #include #include #include +#include #include #include #include @@ -726,6 +727,9 @@ static int vadc_probe(struct platform_device *pdev) vadc_v4l2_subdev_init(sd, pdev, &vadc_ops); + pm_runtime_enable(&pdev->dev); + + pm_runtime_get_sync(&pdev->dev); /* Init VADC */ ret = vadc_of_init(pdev); if (ret < 0) @@ -736,6 +740,9 @@ static int vadc_probe(struct platform_device *pdev) return 0; err: + pm_runtime_put_sync(&pdev->dev); + pm_runtime_disable(&pdev->dev); + v4l2_async_unregister_subdev(&state->sd); clk_disable_unprepare(state->csi_clk); clk_disable_unprepare(state->vadc_clk); return ret; @@ -745,6 +752,8 @@ static int vadc_remove(struct platform_device *pdev) { struct vadc_state *state = platform_get_drvdata(pdev); + pm_runtime_put_sync(&pdev->dev); + pm_runtime_disable(&pdev->dev); v4l2_async_unregister_subdev(&state->sd); clk_disable_unprepare(state->csi_clk); clk_disable_unprepare(state->vadc_clk);