spi: pxa2xx: Add ready signal
authorLubomir Rintel <lkundrak@v3.sk>
Tue, 13 Nov 2018 10:22:27 +0000 (11:22 +0100)
committerMark Brown <broonie@kernel.org>
Tue, 13 Nov 2018 18:02:09 +0000 (10:02 -0800)
Strobe a GPIO line when the slave TX FIFO is filled. This is how the
Embedded Controller on an OLPC XO-1.75 machine, that happens to be a SPI
master, learns that it can initiate a transaction.

Signed-off-by: Lubomir Rintel <lkundrak@v3.sk>
Tested-by: Pavel Machek <pavel@ucw.cz>
Reviewed-by: Geert Uytterhoeven <geert+renesas@glider.be>
Signed-off-by: Mark Brown <broonie@kernel.org>
drivers/spi/spi-pxa2xx.c
drivers/spi/spi-pxa2xx.h

index a057c3be7e3b3f9aa88c8350914eb00c8d1ccb1f..69b221e34b2de1308e6a7a946afbd23f69d3a42d 100644 (file)
@@ -1081,6 +1081,11 @@ static int pxa2xx_spi_transfer_one(struct spi_controller *master,
        if (spi_controller_is_slave(master)) {
                while (drv_data->write(drv_data))
                        ;
+               if (drv_data->gpiod_ready) {
+                       gpiod_set_value(drv_data->gpiod_ready, 1);
+                       udelay(1);
+                       gpiod_set_value(drv_data->gpiod_ready, 0);
+               }
        }
 
        /*
@@ -1778,7 +1783,7 @@ static int pxa2xx_spi_probe(struct platform_device *pdev)
                                if (PTR_ERR(gpiod) == -ENOENT)
                                        continue;
 
-                               status = (int)PTR_ERR(gpiod);
+                               status = PTR_ERR(gpiod);
                                goto out_error_clock_enabled;
                        } else {
                                drv_data->cs_gpiods[i] = gpiod;
@@ -1786,6 +1791,15 @@ static int pxa2xx_spi_probe(struct platform_device *pdev)
                }
        }
 
+       if (platform_info->is_slave) {
+               drv_data->gpiod_ready = devm_gpiod_get_optional(dev,
+                                               "ready", GPIOD_OUT_LOW);
+               if (IS_ERR(drv_data->gpiod_ready)) {
+                       status = PTR_ERR(drv_data->gpiod_ready);
+                       goto out_error_clock_enabled;
+               }
+       }
+
        pm_runtime_set_autosuspend_delay(&pdev->dev, 50);
        pm_runtime_use_autosuspend(&pdev->dev);
        pm_runtime_set_active(&pdev->dev);
index 513c53aaeab233bf5a340d758ff375166f87b51d..4e324da66ef7544fbcbb47edc21e3155b5cb27d0 100644 (file)
@@ -64,6 +64,9 @@ struct driver_data {
 
        /* GPIOs for chip selects */
        struct gpio_desc **cs_gpiods;
+
+       /* Optional slave FIFO ready signal */
+       struct gpio_desc *gpiod_ready;
 };
 
 struct chip_data {