]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
spi: rzv2h-rspi: Fix invalid SPR=0/BRDV=0 clock configuration
authorLad Prabhakar <prabhakar.mahadev-lad.rj@bp.renesas.com>
Fri, 10 Apr 2026 08:05:16 +0000 (09:05 +0100)
committerMark Brown <broonie@kernel.org>
Fri, 10 Apr 2026 12:19:59 +0000 (13:19 +0100)
The combination of SPR=0 and BRDV=0 results in the minimum division
ratio of 2, producing the maximum possible bit rate for a given clock
source. This combination is not supported in two cases:

- On RZ/G3E, RZ/G3L, RZ/V2H(P) and RZ/V2N, RSPI_n_TCLK is fixed at
  200MHz, which would yield 100Mbps. The next hardware manual update
  will explicitly state that since the maximum frequency of the
  RSPICKn clock signal is 50MHz, settings with N=0 and n=0 resulting
  in 100Mbps are prohibited.

- On RZ/T2H and RZ/N2H, when PCLK (125MHz) is used as the clock
  source, SPR=0 and BRDV=0 is explicitly listed as unsupported in
  the hardware manual (Table 36.7).

Skip the SPR=0/BRDV=0 combination in rzv2h_rspi_find_rate_fixed() to
prevent the driver from selecting an invalid clock configuration on the
affected SoCs.

Additionally, remove the now redundant RSPI_SPBR_SPR_PCLK_MIN define
which was previously set to 1 to work around the PCLK restriction, but
was overly broad as it incorrectly blocked valid combinations such as
SPR=0/BRDV=1 (31.25Mbps on PCLK=125MHz).

Fixes: 8b61c8919dff ("spi: Add driver for the RZ/V2H(P) RSPI IP")
Fixes: 1ce3e8adc7d0 ("spi: rzv2h-rspi: add support for using PCLK for transfer clock")
Signed-off-by: Lad Prabhakar <prabhakar.mahadev-lad.rj@bp.renesas.com>
Link: https://patch.msgid.link/20260410080517.2405700-3-prabhakar.mahadev-lad.rj@bp.renesas.com
Signed-off-by: Mark Brown <broonie@kernel.org>
drivers/spi/spi-rzv2h-rspi.c

index 15270f19c69c17dcfbedd71006a0b430d658968f..f62223e106c05efa17be67e1948bb00bd179c177 100644 (file)
@@ -50,7 +50,6 @@
 
 /* Register SPBR */
 #define RSPI_SPBR_SPR_MIN      0
-#define RSPI_SPBR_SPR_PCLK_MIN 1
 #define RSPI_SPBR_SPR_MAX      255
 
 /* Register SPCMD */
@@ -535,6 +534,17 @@ static void rzv2h_rspi_find_rate_fixed(struct clk *clk, u32 hz,
        for (brdv = RSPI_SPCMD_BRDV_MIN; brdv <= RSPI_SPCMD_BRDV_MAX; brdv++) {
                spr = DIV_ROUND_UP(clk_rate, hz * (1 << (brdv + 1)));
                spr--;
+               /*
+                * Skip SPR=0 and BRDV=0 as it is not a valid combination:
+                * - On RZ/G3E, RZ/G3L, RZ/V2H(P) and RZ/V2N, RSPI_n_TCLK is
+                *   fixed at 200MHz and SPR=0 and BRDV=0 results in the maximum
+                *   bit rate of 100Mbps which is prohibited.
+                * - On RZ/T2H and RZ/N2H, when PCLK (125MHz) is used as
+                *   the clock source, SPR=0 and BRDV=0 is explicitly listed
+                *   as unsupported in the hardware manual (Table 36.7).
+                */
+               if (!spr && !brdv)
+                       continue;
                if (spr >= spr_min && spr <= spr_max)
                        goto clock_found;
        }
@@ -568,12 +578,8 @@ static u32 rzv2h_rspi_setup_clock(struct rzv2h_rspi_priv *rspi, u32 hz)
        rspi->info->find_tclk_rate(rspi->tclk, hz, RSPI_SPBR_SPR_MIN,
                                   RSPI_SPBR_SPR_MAX, &best_clock);
 
-       /*
-        * T2H and N2H can also use PCLK as a source, which is 125MHz, but not
-        * when both SPR and BRDV are 0.
-        */
        if (best_clock.error && rspi->info->find_pclk_rate)
-               rspi->info->find_pclk_rate(rspi->pclk, hz, RSPI_SPBR_SPR_PCLK_MIN,
+               rspi->info->find_pclk_rate(rspi->pclk, hz, RSPI_SPBR_SPR_MIN,
                                           RSPI_SPBR_SPR_MAX, &best_clock);
 
        if (!best_clock.clk_rate)