Mike

I already sent a patch some time ago, it addresses this bug and
alot more. See spi-devel-general
<[EMAIL PROTECTED]>,

I am waiting for David B. to comment/apply it. If you want to see this
in 2.6.25 I suggest you remind 'David Brownell' <[EMAIL PROTECTED]>

 Jocke
On Mon, 2008-03-31 at 08:04 -0500, Mike Hench wrote:
> dont write SPMODE reg unless mode changed.
> it causes SPI to go hi-z momentarily
> which can cause a spike on the CLK line
> this is a problem in MMC where /CS is held asserted
> across multiple transactions.
> 
> Signed-off-by: Mike Hench <[EMAIL PROTECTED]>
> 
> ---
> 
> --- linux-2.6.25-rc5.orig/drivers/spi/spi_mpc83xx.c   2008-03-10
> 00:22:27.000000000 -0500
> +++ linux-2.6.25-rc5/drivers/spi/spi_mpc83xx.c        2008-03-31
> 07:37:37.000000000 -0500
> @@ -147,6 +147,7 @@
>  
>       if (value == BITBANG_CS_ACTIVE) {
>               u32 regval =
> mpc83xx_spi_read_reg(&mpc83xx_spi->base->mode);
> +             u32 regval0 = regval;
>               u32 len = spi->bits_per_word;
>               u8 pm;
>  
> @@ -188,9 +189,16 @@
>                       regval |= SPMODE_PM(pm);
>               }
>  
> -             /* Turn off SPI unit prior changing mode */
> -             mpc83xx_spi_write_reg(&mpc83xx_spi->base->mode, 0);
> -             mpc83xx_spi_write_reg(&mpc83xx_spi->base->mode, regval);
> +             // dont write reg unless mode changed.
> +             // it causes SPI to go hi-z momentarily
> +             // which can cause a spike on the CLK line
> +             // this is a problem in MMC where /CS is held asserted
> +             // across multiple transactions.
> +             if(regval != regval0) {
> +                     /* Turn off SPI unit prior changing mode */
> +                     mpc83xx_spi_write_reg(&mpc83xx_spi->base->mode,
> 0);
> +                     mpc83xx_spi_write_reg(&mpc83xx_spi->base->mode,
> regval);
> +             }
>               if (mpc83xx_spi->activate_cs)
>                       mpc83xx_spi->activate_cs(spi->chip_select, pol);
>       }
> 
> _______________________________________________
> Linuxppc-dev mailing list
> Linuxppc-dev@ozlabs.org
> https://ozlabs.org/mailman/listinfo/linuxppc-dev
> 
> 


_______________________________________________
Linuxppc-dev mailing list
Linuxppc-dev@ozlabs.org
https://ozlabs.org/mailman/listinfo/linuxppc-dev

Reply via email to