spi: support CS timing for HW & SW mode
authorleilk.liu <leilk.liu@mediatek.com>
Sun, 7 Feb 2021 03:09:52 +0000 (11:09 +0800)
committerMark Brown <broonie@kernel.org>
Mon, 8 Feb 2021 11:41:22 +0000 (11:41 +0000)
this patch supports the controller's HW CS and SW CS via use cs_gpio.

Signed-off-by: leilk.liu <leilk.liu@mediatek.com>
Link: https://lore.kernel.org/r/20210207030953.9297-3-leilk.liu@mediatek.com
Signed-off-by: Mark Brown <broonie@kernel.org>
drivers/spi/spi.c

index 21ea3e8a00e2c6d47f97d9ab1f54e95f36f78b8a..a247fcac0dc74fd6195fe8acafdde7584963b2e8 100644 (file)
@@ -810,7 +810,8 @@ static void spi_set_cs(struct spi_device *spi, bool enable)
        spi->controller->last_cs_enable = enable;
        spi->controller->last_cs_mode_high = spi->mode & SPI_CS_HIGH;
 
-       if (!spi->controller->set_cs_timing) {
+       if (spi->cs_gpiod || gpio_is_valid(spi->cs_gpio) ||
+           !spi->controller->set_cs_timing) {
                if (enable1)
                        spi_delay_exec(&spi->controller->cs_setup, NULL);
                else
@@ -841,7 +842,8 @@ static void spi_set_cs(struct spi_device *spi, bool enable)
                spi->controller->set_cs(spi, !enable);
        }
 
-       if (!spi->controller->set_cs_timing) {
+       if (spi->cs_gpiod || gpio_is_valid(spi->cs_gpio) ||
+           !spi->controller->set_cs_timing) {
                if (!enable1)
                        spi_delay_exec(&spi->controller->cs_inactive, NULL);
        }
@@ -3464,7 +3466,8 @@ int spi_set_cs_timing(struct spi_device *spi, struct spi_delay *setup,
        size_t len;
        int status;
 
-       if (spi->controller->set_cs_timing) {
+       if (spi->controller->set_cs_timing &&
+           !(spi->cs_gpiod || gpio_is_valid(spi->cs_gpio))) {
                if (spi->controller->auto_runtime_pm) {
                        status = pm_runtime_get_sync(parent);
                        if (status < 0) {