]> www.infradead.org Git - users/jedix/linux-maple.git/commitdiff
spi: bcm-qspi: MSPI_SPCR0_MSB MSTR bit exists only on legacy controllers
authorKamal Dasu <kdasu.kdev@gmail.com>
Mon, 20 Apr 2020 19:08:53 +0000 (15:08 -0400)
committerMark Brown <broonie@kernel.org>
Tue, 21 Apr 2020 18:48:12 +0000 (19:48 +0100)
Set MASTER bit on the MSPI_SPCR0_MSB only for legacy MSPI and HIF_MSPI
controllers.

Fixes: fa236a7ef240 ("spi: bcm-qspi: Add Broadcom MSPI driver")
Signed-off-by: Kamal Dasu <kdasu.kdev@gmail.com>
Link: https://lore.kernel.org/r/20200420190853.45614-10-kdasu.kdev@gmail.com
Signed-off-by: Mark Brown <broonie@kernel.org>
drivers/spi/spi-bcm-qspi.c

index 4b139717ff9e2a8eb053cbbd953812cd8a17829f..23cad49e7405d37655c96b23bcbc392ee9f2b231 100644 (file)
@@ -576,11 +576,17 @@ static void bcm_qspi_hw_set_parms(struct bcm_qspi *qspi,
        spcr = clamp_val(spbr, bcm_qspi_spbr_min(qspi), QSPI_SPBR_MAX);
        bcm_qspi_write(qspi, MSPI, MSPI_SPCR0_LSB, spcr);
 
-       spcr = MSPI_MASTER_BIT;
+       if (!qspi->mspi_maj_rev)
+               /* legacy controller */
+               spcr = MSPI_MASTER_BIT;
+       else
+               spcr = 0;
+
        /* for 16 bit the data should be zero */
        if (xp->bits_per_word != 16)
                spcr |= xp->bits_per_word << 2;
        spcr |= xp->mode & 3;
+
        bcm_qspi_write(qspi, MSPI, MSPI_SPCR0_MSB, spcr);
 
        if (bcm_qspi_has_fastbr(qspi)) {