spi: amlogic-spifc-a1: add support for max_speed_hz
authorMartin Kurbanov <mmkurbanov@sberdevices.ru>
Thu, 6 Jul 2023 11:03:31 +0000 (14:03 +0300)
committerMark Brown <broonie@kernel.org>
Sun, 9 Jul 2023 21:51:31 +0000 (22:51 +0100)
This patch sets the clock rate (spi_transfer->max_speed_hz) from the
amlogic_spifc_a1_exec_op().

Signed-off-by: Martin Kurbanov <mmkurbanov@sberdevices.ru>
Reviewed-by: Neil Armstrong <neil.armstrong@linaro.org>
Link: https://lore.kernel.org/r/20230706110331.19794-3-mmkurbanov@sberdevices.ru
Signed-off-by: Mark Brown <broonie@kernel.org>
drivers/spi/spi-amlogic-spifc-a1.c

index a92e4fc23396b910c3deba4db59b805a560b24bb..605e9e40455ce26c216b4d1e4b5cd421df5b9cb9 100644 (file)
@@ -107,6 +107,7 @@ struct amlogic_spifc_a1 {
        struct clk *clk;
        struct device *dev;
        void __iomem *base;
+       u32 curr_speed_hz;
 };
 
 static int amlogic_spifc_a1_request(struct amlogic_spifc_a1 *spifc, bool read)
@@ -235,6 +236,21 @@ static int amlogic_spifc_a1_write(struct amlogic_spifc_a1 *spifc,
        return amlogic_spifc_a1_request(spifc, false);
 }
 
+static int amlogic_spifc_a1_set_freq(struct amlogic_spifc_a1 *spifc, u32 freq)
+{
+       int ret;
+
+       if (freq == spifc->curr_speed_hz)
+               return 0;
+
+       ret = clk_set_rate(spifc->clk, freq);
+       if (ret)
+               return ret;
+
+       spifc->curr_speed_hz = freq;
+       return 0;
+}
+
 static int amlogic_spifc_a1_exec_op(struct spi_mem *mem,
                                    const struct spi_mem_op *op)
 {
@@ -243,6 +259,10 @@ static int amlogic_spifc_a1_exec_op(struct spi_mem *mem,
        size_t data_size = op->data.nbytes;
        int ret;
 
+       ret = amlogic_spifc_a1_set_freq(spifc, mem->spi->max_speed_hz);
+       if (ret)
+               return ret;
+
        amlogic_spifc_a1_user_init(spifc);
        amlogic_spifc_a1_set_cmd(spifc, SPIFC_A1_USER_CMD(op));