iio: adc: spear_adc: Use device managed function
authorJinjie Ruan <ruanjinjie@huawei.com>
Sat, 26 Aug 2023 06:27:31 +0000 (14:27 +0800)
committerJonathan Cameron <Jonathan.Cameron@huawei.com>
Mon, 11 Sep 2023 19:12:39 +0000 (20:12 +0100)
The devm_clk_get_enabled() helper:
    - calls devm_clk_get()
    - calls clk_prepare_enable() and registers what is needed in order to
      call clk_disable_unprepare() when needed, as a managed resource.

Switch to devm_iio_device_register() and drop the remove function.

This simplifies the code.

Signed-off-by: Jinjie Ruan <ruanjinjie@huawei.com>
Link: https://lore.kernel.org/r/20230826062733.3714169-2-ruanjinjie@huawei.com
Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
drivers/iio/adc/spear_adc.c

index ad54ef798109058c6178f5194e8b2329daa168c8..d24adacfdf539cc253382b58d14697e3b26393b8 100644 (file)
@@ -297,36 +297,27 @@ static int spear_adc_probe(struct platform_device *pdev)
        st->adc_base_spear3xx =
                (struct adc_regs_spear3xx __iomem *)st->adc_base_spear6xx;
 
-       st->clk = devm_clk_get(dev, NULL);
+       st->clk = devm_clk_get_enabled(dev, NULL);
        if (IS_ERR(st->clk)) {
-               dev_err(dev, "failed getting clock\n");
-               return PTR_ERR(st->clk);
-       }
-
-       ret = clk_prepare_enable(st->clk);
-       if (ret) {
                dev_err(dev, "failed enabling clock\n");
-               return ret;
+               return PTR_ERR(st->clk);
        }
 
        irq = platform_get_irq(pdev, 0);
-       if (irq < 0) {
-               ret = irq;
-               goto errout2;
-       }
+       if (irq < 0)
+               return irq;
 
        ret = devm_request_irq(dev, irq, spear_adc_isr, 0, SPEAR_ADC_MOD_NAME,
                               st);
        if (ret < 0) {
                dev_err(dev, "failed requesting interrupt\n");
-               goto errout2;
+               return ret;
        }
 
        if (of_property_read_u32(np, "sampling-frequency",
                                 &st->sampling_freq)) {
                dev_err(dev, "sampling-frequency missing in DT\n");
-               ret = -EINVAL;
-               goto errout2;
+               return -EINVAL;
        }
 
        /*
@@ -343,8 +334,6 @@ static int spear_adc_probe(struct platform_device *pdev)
 
        spear_adc_configure(st);
 
-       platform_set_drvdata(pdev, indio_dev);
-
        init_completion(&st->completion);
 
        indio_dev->name = SPEAR_ADC_MOD_NAME;
@@ -353,27 +342,12 @@ static int spear_adc_probe(struct platform_device *pdev)
        indio_dev->channels = spear_adc_iio_channels;
        indio_dev->num_channels = ARRAY_SIZE(spear_adc_iio_channels);
 
-       ret = iio_device_register(indio_dev);
+       ret = devm_iio_device_register(dev, indio_dev);
        if (ret)
-               goto errout2;
+               return ret;
 
        dev_info(dev, "SPEAR ADC driver loaded, IRQ %d\n", irq);
 
-       return 0;
-
-errout2:
-       clk_disable_unprepare(st->clk);
-       return ret;
-}
-
-static int spear_adc_remove(struct platform_device *pdev)
-{
-       struct iio_dev *indio_dev = platform_get_drvdata(pdev);
-       struct spear_adc_state *st = iio_priv(indio_dev);
-
-       iio_device_unregister(indio_dev);
-       clk_disable_unprepare(st->clk);
-
        return 0;
 }
 
@@ -387,7 +361,6 @@ MODULE_DEVICE_TABLE(of, spear_adc_dt_ids);
 
 static struct platform_driver spear_adc_driver = {
        .probe          = spear_adc_probe,
-       .remove         = spear_adc_remove,
        .driver         = {
                .name   = SPEAR_ADC_MOD_NAME,
                .of_match_table = of_match_ptr(spear_adc_dt_ids),