On 14 March 2013 02:10, Doug Anderson <dianders@xxxxxxxxxxxx> wrote: > Without this change the exynos adc controller needed to have its phy > enabled in some out-of-driver C code. Add support for specifying the > phy enable register by listing it in the reg list. > > Signed-off-by: Doug Anderson <dianders@xxxxxxxxxxxx> Worked for me, Its needed for Exynos5250 and future versions too. Tested on SMDK5250. > --- > Changes in v2: None > > .../devicetree/bindings/arm/samsung/exynos-adc.txt | 4 ++-- > drivers/iio/adc/exynos_adc.c | 14 +++++++++++++- > 2 files changed, 15 insertions(+), 3 deletions(-) > > diff --git a/Documentation/devicetree/bindings/arm/samsung/exynos-adc.txt b/Documentation/devicetree/bindings/arm/samsung/exynos-adc.txt > index 96db940..05be151 100644 > --- a/Documentation/devicetree/bindings/arm/samsung/exynos-adc.txt > +++ b/Documentation/devicetree/bindings/arm/samsung/exynos-adc.txt > @@ -15,7 +15,7 @@ Required properties: > Must be "samsung,exynos-adc-v2" for > future controllers. > - reg: Contains ADC register address range (base address and > - length). > + length) and the address of the phy enable register. > - interrupts: Contains the interrupt information for the timer. The > format is being dependent on which interrupt controller > the Samsung device uses. > @@ -30,7 +30,7 @@ Example: adding device info in dtsi file > > adc: adc@12D10000 { > compatible = "samsung,exynos-adc-v1"; > - reg = <0x12D10000 0x100>; > + reg = <0x12D10000 0x100>, <0x10040718 0x4>; > interrupts = <0 106 0>; > #io-channel-cells = <1>; > io-channel-ranges; > diff --git a/drivers/iio/adc/exynos_adc.c b/drivers/iio/adc/exynos_adc.c > index ed6fdd7..5ab0dfd 100644 > --- a/drivers/iio/adc/exynos_adc.c > +++ b/drivers/iio/adc/exynos_adc.c > @@ -85,6 +85,7 @@ enum adc_version { > > struct exynos_adc { > void __iomem *regs; > + void __iomem *enable_reg; > struct clk *clk; > unsigned int irq; > struct regulator *vdd; > @@ -269,13 +270,19 @@ static int exynos_adc_probe(struct platform_device *pdev) > info = iio_priv(indio_dev); > > mem = platform_get_resource(pdev, IORESOURCE_MEM, 0); > - > info->regs = devm_request_and_ioremap(&pdev->dev, mem); > if (!info->regs) { > ret = -ENOMEM; > goto err_iio; > } > > + mem = platform_get_resource(pdev, IORESOURCE_MEM, 1); > + info->enable_reg = devm_request_and_ioremap(&pdev->dev, mem); > + if (!info->enable_reg) { > + ret = -ENOMEM; > + goto err_iio; > + } > + > irq = platform_get_irq(pdev, 0); > if (irq < 0) { > dev_err(&pdev->dev, "no irq resource?\n"); > @@ -295,6 +302,8 @@ static int exynos_adc_probe(struct platform_device *pdev) > goto err_iio; > } > > + writel(1, info->enable_reg); > + > info->clk = devm_clk_get(&pdev->dev, "adc"); > if (IS_ERR(info->clk)) { > dev_err(&pdev->dev, "failed getting clock, err = %ld\n", > @@ -370,6 +379,7 @@ static int exynos_adc_remove(struct platform_device *pdev) > exynos_adc_remove_devices); > regulator_disable(info->vdd); > clk_disable_unprepare(info->clk); > + writel(0, info->enable_reg); > iio_device_unregister(indio_dev); > free_irq(info->irq, info); > iio_device_free(indio_dev); > @@ -395,6 +405,7 @@ static int exynos_adc_suspend(struct device *dev) > } > > clk_disable_unprepare(info->clk); > + writel(0, info->enable_reg); > regulator_disable(info->vdd); > > return 0; > @@ -410,6 +421,7 @@ static int exynos_adc_resume(struct device *dev) > if (ret) > return ret; > > + writel(1, info->enable_reg); > clk_prepare_enable(info->clk); > > exynos_adc_hw_init(info); > -- > 1.8.1.3 > > -- > To unsubscribe from this list: send the line "unsubscribe linux-kernel" in > the body of a message to majordomo@xxxxxxxxxxxxxxx > More majordomo info at http://vger.kernel.org/majordomo-info.html > Please read the FAQ at http://www.tux.org/lkml/ -- Shine bright, (: Nav :) -- To unsubscribe from this list: send the line "unsubscribe linux-iio" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html