OSDN Git Service

spi: pl022: Drop custom per-chip cs_control
authorLinus Walleij <linus.walleij@linaro.org>
Tue, 30 Mar 2021 16:49:05 +0000 (18:49 +0200)
committerMark Brown <broonie@kernel.org>
Wed, 31 Mar 2021 12:54:27 +0000 (13:54 +0100)
Drop the custom cs_control() assigned through platform data,
we have no in-tree users and the only out-of-tree use I have
ever seen of this facility is to pull GPIO lines, which is
something the driver can already do for us.

Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
Link: https://lore.kernel.org/r/20210330164907.2346010-1-linus.walleij@linaro.org
Signed-off-by: Mark Brown <broonie@kernel.org>
drivers/spi/spi-pl022.c
include/linux/amba/pl022.h

index 559d179..8a475fd 100644 (file)
@@ -412,7 +412,6 @@ struct pl022 {
  * @enable_dma: Whether to enable DMA or not
  * @read: function ptr to be used to read when doing xfer for this chip
  * @write: function ptr to be used to write when doing xfer for this chip
- * @cs_control: chip select callback provided by chip
  * @xfer_type: polling/interrupt/DMA
  *
  * Runtime state of the SSP controller, maintained per chip,
@@ -427,23 +426,10 @@ struct chip_data {
        bool enable_dma;
        enum ssp_reading read;
        enum ssp_writing write;
-       void (*cs_control) (u32 command);
        int xfer_type;
 };
 
 /**
- * null_cs_control - Dummy chip select function
- * @command: select/delect the chip
- *
- * If no chip select function is provided by client this is used as dummy
- * chip select
- */
-static void null_cs_control(u32 command)
-{
-       pr_debug("pl022: dummy chip select control, CS=0x%x\n", command);
-}
-
-/**
  * internal_cs_control - Control chip select signals via SSP_CSR.
  * @pl022: SSP driver private data structure
  * @command: select/delect the chip
@@ -470,8 +456,6 @@ static void pl022_cs_control(struct pl022 *pl022, u32 command)
                internal_cs_control(pl022, command);
        else if (gpio_is_valid(pl022->cur_cs))
                gpio_set_value(pl022->cur_cs, command);
-       else
-               pl022->cur_chip->cs_control(command);
 }
 
 /**
@@ -1829,7 +1813,6 @@ static const struct pl022_config_chip pl022_default_chip_info = {
        .ctrl_len = SSP_BITS_8,
        .wait_state = SSP_MWIRE_WAIT_ZERO,
        .duplex = SSP_MICROWIRE_CHANNEL_FULL_DUPLEX,
-       .cs_control = null_cs_control,
 };
 
 /**
@@ -1940,13 +1923,8 @@ static int pl022_setup(struct spi_device *spi)
 
        /* Now set controller state based on controller data */
        chip->xfer_type = chip_info->com_mode;
-       if (!chip_info->cs_control) {
-               chip->cs_control = null_cs_control;
-               if (!gpio_is_valid(pl022->chipselects[spi->chip_select]))
-                       dev_warn(&spi->dev,
-                                "invalid chip select\n");
-       } else
-               chip->cs_control = chip_info->cs_control;
+       if (!gpio_is_valid(pl022->chipselects[spi->chip_select]))
+               dev_warn(&spi->dev, "invalid chip select\n");
 
        /* Check bits per word with vendor specific range */
        if ((bits <= 3) || (bits > pl022->vendor->max_bpw)) {
index 131b27c..29274ce 100644 (file)
@@ -265,8 +265,6 @@ struct pl022_ssp_controller {
  * @duplex: Microwire interface: Full/Half duplex
  * @clkdelay: on the PL023 variant, the delay in feeback clock cycles
  * before sampling the incoming line
- * @cs_control: function pointer to board-specific function to
- * assert/deassert I/O port to control HW generation of devices chip-select.
  */
 struct pl022_config_chip {
        enum ssp_interface iface;
@@ -280,7 +278,6 @@ struct pl022_config_chip {
        enum ssp_microwire_wait_state wait_state;
        enum ssp_duplex duplex;
        enum ssp_clkdelay clkdelay;
-       void (*cs_control) (u32 control);
 };
 
 #endif /* _SSP_PL022_H */