OSDN Git Service

spi: img-spfi: Convert to use GPIO descriptors
authorLinus Walleij <linus.walleij@linaro.org>
Thu, 25 Jun 2020 20:14:22 +0000 (22:14 +0200)
committerMark Brown <broonie@kernel.org>
Wed, 1 Jul 2020 22:21:29 +0000 (23:21 +0100)
This converts the IMG SPFI SPI driver to use GPIO descriptors
as obtained from the core instead of GPIO numbers.

The driver was already relying on the core code to look up
the GPIO numbers from the device tree and allocate memory for
storing state etc. By moving to use descriptors handled by
the core we can delete the setup/cleanup functions and
the device state handler that were only dealing with this.

Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
Cc: Ionela Voinescu <ionela.voinescu@imgtec.com>
Cc: Sifan Naeem <sifan.naeem@imgtec.com>
Link: https://lore.kernel.org/r/20200625201422.208640-1-linus.walleij@linaro.org
Signed-off-by: Mark Brown <broonie@kernel.org>
drivers/spi/spi-img-spfi.c

index 8543f5e..b068537 100644 (file)
@@ -9,7 +9,6 @@
 #include <linux/clk.h>
 #include <linux/delay.h>
 #include <linux/dmaengine.h>
-#include <linux/gpio.h>
 #include <linux/interrupt.h>
 #include <linux/io.h>
 #include <linux/irq.h>
@@ -102,10 +101,6 @@ struct img_spfi {
        bool rx_dma_busy;
 };
 
-struct img_spfi_device_data {
-       bool gpio_requested;
-};
-
 static inline u32 spfi_readl(struct img_spfi *spfi, u32 reg)
 {
        return readl(spfi->regs + reg);
@@ -442,54 +437,6 @@ static int img_spfi_unprepare(struct spi_master *master,
        return 0;
 }
 
-static int img_spfi_setup(struct spi_device *spi)
-{
-       int ret = -EINVAL;
-       struct img_spfi_device_data *spfi_data = spi_get_ctldata(spi);
-
-       if (!spfi_data) {
-               spfi_data = kzalloc(sizeof(*spfi_data), GFP_KERNEL);
-               if (!spfi_data)
-                       return -ENOMEM;
-               spfi_data->gpio_requested = false;
-               spi_set_ctldata(spi, spfi_data);
-       }
-       if (!spfi_data->gpio_requested) {
-               ret = gpio_request_one(spi->cs_gpio,
-                                      (spi->mode & SPI_CS_HIGH) ?
-                                      GPIOF_OUT_INIT_LOW : GPIOF_OUT_INIT_HIGH,
-                                      dev_name(&spi->dev));
-               if (ret)
-                       dev_err(&spi->dev, "can't request chipselect gpio %d\n",
-                               spi->cs_gpio);
-               else
-                       spfi_data->gpio_requested = true;
-       } else {
-               if (gpio_is_valid(spi->cs_gpio)) {
-                       int mode = ((spi->mode & SPI_CS_HIGH) ?
-                                   GPIOF_OUT_INIT_LOW : GPIOF_OUT_INIT_HIGH);
-
-                       ret = gpio_direction_output(spi->cs_gpio, mode);
-                       if (ret)
-                               dev_err(&spi->dev, "chipselect gpio %d setup failed (%d)\n",
-                                       spi->cs_gpio, ret);
-               }
-       }
-       return ret;
-}
-
-static void img_spfi_cleanup(struct spi_device *spi)
-{
-       struct img_spfi_device_data *spfi_data = spi_get_ctldata(spi);
-
-       if (spfi_data) {
-               if (spfi_data->gpio_requested)
-                       gpio_free(spi->cs_gpio);
-               kfree(spfi_data);
-               spi_set_ctldata(spi, NULL);
-       }
-}
-
 static void img_spfi_config(struct spi_master *master, struct spi_device *spi,
                            struct spi_transfer *xfer)
 {
@@ -659,12 +606,11 @@ static int img_spfi_probe(struct platform_device *pdev)
                        master->max_speed_hz = max_speed_hz;
        }
 
-       master->setup = img_spfi_setup;
-       master->cleanup = img_spfi_cleanup;
        master->transfer_one = img_spfi_transfer_one;
        master->prepare_message = img_spfi_prepare;
        master->unprepare_message = img_spfi_unprepare;
        master->handle_err = img_spfi_handle_err;
+       master->use_gpio_descriptors = true;
 
        spfi->tx_ch = dma_request_chan(spfi->dev, "tx");
        if (IS_ERR(spfi->tx_ch)) {